高并发编程
众所周知,在Java的知识体系中,并发编程是非常重要的一环,也是面试的必问题,一个好的Java程序员是必须对并发编程这块有所了解的。然而不论是哪个国家,什么背景的 Java 开发者,都对自己写的并发程序相当自信,但也会在出问题时表现得很诧异甚至一筹莫展。可见,Java 并发编程显然不是一件能速成的能力,基础搭得越好,越全面,在实践中才会有更深刻的理解。
因此,大家不难发现 Java 并发问题一直是各个大厂面试的重点之一。我在平时的面试中,也发现很多候选人对一些基本的并发概念表示没听过,或原理不理解,可能知道一些却又讲不清楚,最终导致面试失败。
学习java并发就像进入了另外一个学习领域,就像学习一门新的编程语言,或者是学习一套新的语言概念,要理解并发编程,其难度跟理解面向对象编程难度差不多。你花一点功夫,就可以理解它的基本机制,但是要想真正掌握它的本质,就需要深入的学习与理解。在分享7个并发体系知识的学习导图给大家(文末有xmind源文件及更多架构视频及文档资料免费领取)!
一、并发基础
二、线程池
三、并发工具类
四、并发集合
五、阻塞队列
六、atomic
七、锁
CurentHashMap :
为什么有重点的参数。为什么这么设置。
AQS
JMM模型。
悲观锁
AQS同步器独占锁的实现: 并发编程核心框架AQS :
CPU最小的调度单位是线程 CPU不支持超线程 不能同时炮四个线程
、
同步控制处理 : 同步器: synchronize 基于jvm底层 基于C++ 底层行为不可控 2. AQS
abstractQueueSynchronized 不利用任何 jvm记忆java可变行为实现同步
保证同步实现:
CAS保证原子性 保证元素的修改。通过自旋 去控制阻塞不让她跳出 循环之外。 为了让自旋的线程 不能一直转下去需要阻塞住 用LockSupportPark UNpark 让她阻塞住。