27道顶尖的Java多线程、锁、内存模型面试题!
1、Synchronized 用过吗,其原理是什么?
2、你刚才提到获取对象的锁,这个“锁”到底是什么?如何确定对象的锁?
3、什么是可重入性,为什么说 Synchronized 是可重入锁?
4、JVM 对Java 的原生锁做了哪些优化?
5、为什么说Synchronized 是非公平锁?
6、什么是锁消除和锁粗化?
7、为什么说Synchronized 是一个悲观锁?乐观锁的实现原理又是什么?什么是 CAS,它有什么特性?
8、乐观锁一定就是好的吗?
9、跟 Synchronized 相比,可重入锁 ReentrantLock 其实现原理有什么不同?
10、那么请谈谈 AQS 框架是怎么回事儿?
11、请尽可能详尽地对比下 Synchronized 和 ReentrantLock 的异同。
12、ReentrantLock 是如何实现可重入性的?
13、除了 ReetrantLock,你还接触过 JUC 中的哪些并发工具?
14、请谈谈 ReadWriteLock 和 StampedLock。
·
15、如何让 Java 的线程彼此同步?你了解过哪些同步器?请分别介绍下。
16、CyclicBarrier 和 CountDownLatch 看起来很相似,请对比下呢?
17、Java 中的线程池是如何实现的?
18、创建线程池的几个核心构造参数?
19、线程池中的线程是怎么创建的?是一开始就随着线程池的启动创建好的吗?
20、既然提到可以通过配置不同参数创建出不同的线程池,那么 Java 中默认实现好的线程池又有哪些呢?请比较它们的异同。
21、如何在 Java线程池中提交线程?
22、什么是 Java 的内存模型,Java 中各个线程是怎么彼此看到对方的变量的?
23、请谈谈volatile 有什么特点,为什么它能保证变量对所有线程的可见性?
24、既然volatile 能够保证线程间的变量可见性,是不是就意味着基于 volatile 变量的运算就是并发安全的?
25、请对比下volatile 对比 Synchronized 的异同。
26、请谈谈ThreadLocal 是怎么解决并发安全的?
27、很多人都说要慎用ThreadLocal,谈谈你的理解,使用 ThreadLocal 需要注意些什么?