这个图是来自王宝令老师的,只用于学习,图中的协作,实际就是线程通信。
并发编程的三大问题根源:可见性(缓存导致),原子性(线程切换),有序性(编译优化,指令重排)。
只要保证了这三个问题,那么就不会出现并发问题。
比如:volatile变量只能保证可见性和有序性,没有保证原子性(互斥锁保证原子性)。
所以并发包中的锁lock的核心就是volatile修饰公共资源(state),然后对公共资源的操作使用CAS来保证修改公共资源(state)时,只能一个线程执行成功。这样就保证了可见性,有序性,原子性;功能上等同于synchronized。
并发编程的俩大核心问题:互斥(同一时刻只能一个线程执行)、同步(线程通信,协作)。
并发编程的基础理论模型支持:java内存模型。
个人学习java并发的经历是,上来直接看juc下各种锁的源码实现,最后发现一直停留在会用阶段,很难提高。直到后来学习了java内存模型之后,还有并发问题三大根源之后,再次学习,然后才做到有所提高。总之,要想学好java并发,基础一定是要先学内存模型。