Java并发编程艺术----读书笔记(三)
原创
©著作权归作者所有:来自51CTO博客作者程序员黄小斜的原创作品,请联系作者获取转载授权,否则将追究法律责任
3java内存模型
java线程利用共享内存进行通信
实例、静态内容、数组、类都存在堆内存,在线程间共享。
而局部变量和方法参数等不共享。
a线程将共享变量写入主内存再被b读取到。
java的源代码编译和处理会经过指令重排。
缓冲区可以提高效率,但可能导致指令重排。
读脏数据:
内存屏障可以组织特定重排序
一个模型用来保证先后顺序
保证重排序不影响单线程的的执行结果。即不会对存在数据依赖的操作做重排序
单线程按顺序执行指令只是一个幻觉!
指令重排可能导致多线程结果出错。
volatile变量的读写过程。volatile变量改写时,其他线程的内存中改变量会置为无效
volatile通过内存屏障实现增强语义
锁的语义与volatile几乎一致。
公平锁:读volatile变量,如果可以则获取锁,执行操作,再写volatile变量。
非公平:不论是否可以获取锁,先用cas操作读volatile变量并修改。
于是这两个锁都有volatile的读写语义。
什么是cas?
cas操作就是比较并交换,可以用这个原理实现原子操作,但是本身存在一些不足。
新版jdk解决了cas操作所存在的一些问题,可以赋予cas读写volatile变量的语义,从而使多线程的指令不会产生错误重排序,并且可以较好地实现原子操作,使多线程的通信成为可能,这也是并发包concurrent的基础
并发包实现原理
final:略
单例模式中使用的双重检查锁定
比较两个可行方案