1:Synchronized分为偏向锁,轻量级锁,重量级锁,可以使用jol查看markword
偏向锁:上厕所案例只有一个用户在门口贴上标签,这是我占用的
轻量级锁:多个线程抢占情况下,偏向锁先执行,然后将标签撕下来,其他多个线程抢占贴标签
重量级锁:有一个等待队列,多线程进入等待队列里面,一个线程拿到后,通过CFS算法调度等待队列
用户态内核态:用户态不走操作系统,内核态走操作系统,重量级锁走操作系统所以慢
2:cas compareAndSwarp 从内存中拿到值与替换值,拿到值与内存值比较,如果一样直接替换,不一样再到内存中拿重复执行上述步骤
3:volatile
内存可见性:JMM模型,线程本地内存改变了会通知另外一个线程到主存中去拿刷新后的值
防止指令重排:DCL案例+volatile,防止对象指令重排(内存屏障),先引用后赋值,使用对象是未赋值的
4:MESI 缓存行一致性
cpu分为三级缓存,L1,L2,L3,每次从内存拿64个byte,cpu中1core从内存中拿到x,y,修改x后,会使cpu的2core失效,从内存中重新取值。案例:RingBuffer,在常量前与常量后是7个long类型的数据,array[0]和array[1]各拿到的是64byte,一个修改后并不需要通知另外一个,所以此优化执行效率快