1. Synchronized 用过吗,其原理是什么? synchronized是什么,用法及原理
    2. 你刚才提到获取对象的锁,这个“锁”到底是什么?如何确定对象的锁? Synchronized方法锁、对象锁、类锁区别
    3. 什么是可重入性,为什么说 Synchronized 是可重入锁? synchronized 是可重入锁吗?为什么?
    4. JVM 对 Java 的原生锁做了哪些优化? Java-JVM 锁优化
    5. 为什么说 Synchronized 是非公平锁? Synchronized
    6. 什么是锁消除和锁粗化?Synchronized
    7. 为什么说 Synchronized 是一个悲观锁?乐观锁的实现原理又是什么?什么是 CAS,它有什么特性? Synchronized
    8. 乐观锁一定就是好的吗?Synchronized
    9. 跟 Synchronized 相比,可重入锁 ReentrantLock 其实现原理有什么不同? Synchronized
    10. 那么请谈谈 AQS 框架是怎么回事儿?Synchronized
    11. 请尽可能详尽地对比下 Synchronized 和 ReentrantLock 的异同。 Synchronized
    12. ReentrantLock 是如何实现可重入性的?Synchronized
    13. 除了 ReetrantLock,你还接触过 JUC 中的哪些并发工具?Synchronized
    14. 请谈谈 ReadWriteLock 和 StampedLock。Synchronized
    15. 如何让 Java 的线程彼此同步?你了解过哪些同步器?请分别介绍下。 Synchronized
    16. CyclicBarrier 和 CountDownLatch 看起来很相似,请对比下呢? Synchronized

    CountDownLatch和CyclicBarrier都能够实现线程之间的等待,只不过它们的侧重点不同:
    ①CountDownLatch一般用于某个线程A等待若干个其他线程执行完任务之后才执行。
    ②CyclicBarrier一般用于一组线程互相等待至某个状态然后同时执行。
    ③CountDownLatch是不能重用的,而CyclicBarrier可以重用。

    1. Java 线程池相关问题
    2. Java 中的线程池是如何实现的(线程池(包含什么,core、max联系)原理?)?
    3. 创建线程池的几个核心构造参数?
    4. 线程池中的线程是怎么创建的?是一开始就随着线程池的启动创建好的吗?
    5. 既然提到可以通过配置不同参数创建出不同的线程池,那么 Java 中默认实现好的线程池又有哪些呢?请比较它们的异同
    6. 如何在 Java 线程池中提交线程?
    7. 什么是 Java 的内存模型,Java 中各个线程是怎么彼此看到对方的变量的?
    8. 请谈谈 volatile 原理以及特点,为什么它能保证变量对所有线程的可见性?
    9. 既然 volatile 能够保证线程间的变量可见性,是不是就意味着基于 volatile 变量的运算就是并发安全的?
    10. 请对比下 volatile 对比 Synchronized 的异同。 volatile与synchronized的区别
    11. 请谈谈 ThreadLocal 是怎么解决并发安全的? 谈谈Java中的ThreadLocal
    12. 很多人都说要慎用 ThreadLocal,谈谈你的理解,使用 ThreadLocal 需要注意些什么?
    13. JMM(主内存、工作内存、happens-before)是什么? 什么是Java内存模型中的happens-before
    14. 有哪些无锁数据结构?无锁实现的原理? 无锁数据结构(Lock-Free Data Structures)
    15. 并行和并发有什么区别?
    16. 线程和进程的区别?
    17. 守护线程是什么?
    18. 创建线程有哪几种方式? 多线程之创建线程有哪几种方式?
    19. 说一下 runnable 和 callable 有什么区别? 说说Runnable与Callable
    20. 线程有哪些状态?
    21. sleep() 和 wait() 有什么区别?
    22. notify()和 notifyAll()有什么区别?
    23. 线程的 run()和 start()有什么区别?
    24. 创建线程池有哪几种方式?
    25. 线程池都有哪些状态?
    26. 线程池中 submit()和 execute()方法有什么区别?
    27. 在 java 程序中怎么保证多线程的运行安全?
    28. 多线程锁的升级原理是什么?
    29. 什么是死锁?
    30. 怎么防止死锁?
    31. synchronized 和 Lock 有什么区别? synchronized与Lock的区别
    32. synchronized 和 ReentrantLock 区别是什么? ReentrantLock详解 以及与synchronized的区别
    33. 说一下 atomic 的原理? Java中Atomic包的实现原理及应用
    34. Java并发编程:Synchronized底层优化(偏向锁、轻量级锁)
    35. Java 并发编程:线程间的协作(wait/notify/sleep/yield/join)
    36. java并发编程:共享性、互斥性、原子性、可见性、有序性
    37. 锁实现(多线程中的锁系统(四)-谈谈自旋锁
    38. cas原理 (理解casJava并发编程总结2——慎用CAS
    39. volatile使用场景 (Java并发编程:volatile关键字解析Java 并发编程:volatile的使用及其原理
    40. synchronized是什么Synchronized 有几种用法Java并发编程:Synchronized及其实现原理
    41. 重入锁
    42. Java线程池源码及原理