(转)喜马拉雅2018 Java面试题目
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了(转)喜马拉雅2018 Java面试题目,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1630字,纯文字阅读大概需要3分钟。
内容图文
背景:将网上的题目整理下。
java基础
1:hashTable hashMap ConcurrentHashMap 的区别、数据结构、线程安全
2:equals和==区别, 重写equals一定要重写hashcode方法吗?为什么?hashcode方法有什么作用?
这个万年不变的面试题,这是何等的卧槽
==说明:
对于基本类型来说 ,==比较两个基本类型的值是否相等,
对于引用类型来说,==比较的是内个引用类型的内存地址
equals说明:
equals用来比较的是两个对象的内容是否相等,由于所有的类都是继承自java.lang.Object类的,所以适用于所有对象,如果没有对该方法 进行覆盖的话,调用的仍然是Object类中的方法,而Object中的equals方法返回的却是==的判断。
重写equals一般是要重写hashcode方法的,首先equals与hashcode间的关系是这样的:
1、如果两个对象相同(即用equals比较返回true),那么它们的hashCode值一定要相同;
2、如果两个对象的hashCode相同,它们并不一定相同(即用equals比较返回false)
比如说两个字符串的hashcode相同,但是这两个字符串可以是不同的字符串,对象也是同理,自己理解的。
至于hashcode有什么用?
为了提高程序的效率才实现了hashcode方法,先进行hashcode的比较,如果不同,那没就不必在进行equals的比较了,这样就大大减少 了equals比较的次数,这对比需要比较的数量很大的效率提高是很明显的,一个很好的例子就是在集合中的使用;
(转)从一道面试题彻底搞懂hashCode与equals的作用与区别及应当注意的细节
3:线程池的工作机制,Java通过Executors工具类创建出来的线程池有什么区别,为什么这样定义?
4:线程池有哪些参数,具体含义是什么?
4:AQS 重入锁 读写锁 countdownlatch 栅栏(cyclicBarrier) 信号量(semaphore)
5:有四个线程A、B、C、D、E,现在需要E线程在ABCD四个线程结束之后再执行
控制线程顺序执行 我知道的
1. join 让主线程等待子线程运行结束后再继续运行
2. 利用并发包里的Excutors的newSingleThreadExecutor产生一个单线程的线程池,而这个线程池的底层原理就是一个先进先出(FIFO)的 队列。代码中executor.submit依次添加了123线程,按照FIFO的特性,执行顺序也就是123的执行结果,从而保证了执行顺序。
3. 使用 CountDownLatch 控制多个线程执行顺序 cutDown()方法和await()方法 参考:https://www.cnblogs.com/flyme/p/4568063.html
6:Java序列化,有ID和没ID会出现问题吗?
(转)java 序列化ID的作用
7:JVM内存模型,为什么survivor需要有2个。
survivor需要2个,主要是为了规避内存碎片化
8:GC算法,回收器
9:类加载机制
10. synchronized和lock的区别
11 手写生产者消费者
mysql
1:索引都有什么类型
2:聚集索引和非聚集索引,主键删掉之后还有聚集索引吗?
3:建了索引,什么时候会不命中索引
4:innodb与myisam存储引擎的区别
5:分库分表,主从复制的延迟
6:查询优化,
redis
淘汰机制
失效策略
持久化rdb、aof
pipeline
主从、集群
数据结构
1:链表,链表倒置、节点交换
2:Btree B+tree 红黑树
协议
tcp
http
原文:https://www.cnblogs.com/lixuwu/p/10662412.html
内容总结
以上是互联网集市为您收集整理的(转)喜马拉雅2018 Java面试题目全部内容,希望文章能够帮你解决(转)喜马拉雅2018 Java面试题目所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。