回想一个多月前,那时候还在老家自我隔离,接到腾讯发来的远程面试邀请,那叫一个激动呀。毕竟那时失业在家,心里五味成杂,就想着尽快投简历面试找个工作。结果却在败给了这该死的高并发,哎,那一下真打击到我了。幸好暂时身上没有什么经济压力,我也是个打不死的小强,不服输,想再战。这不,硬着头皮苦心钻研学习,整整25天,感觉高并发的很多知识都被我摸透了,而且我还自己琢磨整出了一份并发宝典。自我感觉良好,拿出来给广大网友一起鉴定学习看看,以后面试复习学习就靠它了!
注意注意:因为要控制文章篇幅,所以都是以截图方式展示内容。想要借鉴学习的朋友加下方小助理VX:mf23579,即可免费领取到!
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 应用篇
- 效率
- 限制
- 互斥
- 同步和异步
- 缓存
- 分治统筹
- 定时
3.2《JAVA并发编程实践》
第1部分 基础
- 第2章 线程安全
- 第3章 共享对象
- 第4章 组合对象
- 第5章 构建块
第2部分 构建并发应用程序
- 第6章 任务执行
- 第7章 取消和关闭
- 第8章 应用线程池
- 第9章 GUI应用程序
第3部分 活跃度、性能和测试
- 第10章 避免活跃度危险
- 第11章 性能和可伸缩性
- 第12章 测试并发程序
第4部分 高级主题
- 第13章 显示锁
- 第14章 构建自定义的同步工具
- 第15章 原子变量与非阻塞同步机制
- 第16章 Java存储模型
最后想说一句,我的并发宝典就这么多,因为要控制文章篇幅,所以都是以截图方式展示内容。想要借鉴学习的朋友加下小助理VX:mf23579,即可免费领取到!