厉害了!尚硅谷 mysql 中 employees 表,腾讯 T2 手把手教你
01 并发宝典:面试专题
面试专题分为四个部分,分别如下
Synchronized 相关问题
可重入锁 ReentrantLock 及其他显式锁相关问题
Java 线程池相关问题
Java 内存模型相关问题
1.1 Synchronized 相关问题(这里整理了八问)
问题一:Synchronized 用过吗?其原理是什么?
问题二:你刚才提到获取对象的锁 ,这个“ 锁 ”到底是什么?如何确定对象的锁?
问题 三:什么是可重入性 , 为什么说 Synchronized 是可重入锁?
问题四:JVM 对 Java 的原生锁做了哪些优化?
问题五:为什么说 Synchronized 是非公平锁?
问题六:什么是锁消除和锁粗化 ?
问题七:为什么说 Synchronized 是一个悲观锁?乐观锁的实现原理又是什么?什么是 CAS,它有 什么特性?
问题八:乐观锁一定就是好的吗?
1.2 可重入锁 ReentrantLock 及其他显式锁相关问题(八问)
问题一: 跟 Synchronized 相 比 ,可重入锁 ReentrantLock 其实现原理有什么不同?
问题二:那么请谈谈 AQS 框架是怎么回事儿?
问题三:请尽可能详尽地对比下 Synchronized 和 ReentrantLock 的 异 同
问题四: ReentrantLock 是如何实现可重入性的?
问题五: 除了 ReetrantLock,你还接触过 JUC 中的哪些并发工具?
问题六: 请谈谈 ReadWriteLock 和 StampedLock。
问题七: 如何让 Java 的线程彼此同步?你了解过哪些同步器?请分别介绍下 。
问题八: CyclicBarrier 和 CountDownLatch 看起来很相似,请对比下呢?
1.3 Java 线程池相关问题(六问)
问题一:Java 中的线程池是如何实现的?
问题二:创建线程池的几个核心构造参数?
问题三:线程池中的线程是怎么创建的?是一开始就随着线程池的启动创建好的吗?
问题四:既然提到可以通过配置不同参数创建出不同的线程池,那么 Java 中默认实现好的线程池又 有哪些呢?请比较它们的异同 。
问题六:如何在 Java 线程池中提交线程?
1.4 Java 内存模型相关问题(六问)
问题一:什么是 Java 的内存模型,Java 中各个线程是怎么彼此看到对方的变量的?
问题二:请谈谈 volatile 有什么特点,为什么它能保证变量对所有线程的可见性?
问题三:既然 volatile 能够保证线程间的变量可见性,是不是就意味着基于 volatile 变量的运算就是并 发安全的 ?
问题四:请对比下 volatile 对比 Synchronized 的异同
问题六:很多人都说要慎用 ThreadLocal,谈谈你的理解,使用 ThreadLocal 需要注意些什么?
02 并发宝典:体系大纲专题
Java 并发体系
多线程并发编程大纲
体系大纲是个人对知识的总结梳理,全程用的 xmind 手绘,不过文件不能上传,所以这里都是上传的图片形式,不过有原件
2.1 Java 并发体系
2.2 多线程并发编程
03 并发宝典:笔记专题
3.1 手写四份并发笔记:并发编程+原理+模式+应用
3.1.1 并发编程
1.概览
⒉进程与线程
3.Java 线程
4.共享模型之管程
5.共享模型之内存
6.共享模型之无锁
7.共享模型之不可变
8.共享模型之工具
3.1.2 原理篇
指令级并行原理
CPU 缓存结构原理
volatile l 原理
final 原理
Monitor 原理
synchronized 原理
synchronized 原理进阶
wait notify l 原理
join 原理
park unpark 原理
AQS 原理
ReentrantLock 原理
读写锁原理
Semaphore 原理
ConcurrentHashMap 原理
LinkedBlockingQueue 原理
ConcurrentLinkedQueue 原理
3.1.3 模式篇
同步模式之保护性暂停
同步模式之 Balking
同步模式之顺序控制
异步模式之生产者/消费者
异步模式之工作线程
终止模式之两阶段终止模式
线程安全单例
享元模式
3.1.4 应用篇
效率
限制
互斥
同步和异步
缓存
分治统筹
定时
最后
我还为大家准备了一套体系化的架构师学习资料包以及 BAT 面试资料,供大家参考及学习
已经将知识体系整理好(源码,笔记,PPT,学习视频)
评论