多线程
资源锁
锁可以保护共享资源,避免并发更新造成的数据错误。只有持有锁的线程才能访问被保护资源。线程在访问资源之前必须获取锁,访问完成后一定要记得释放锁。
JMM(java内存模型)
JMM的特性:
- 线程间可见性
- 原子性
- 有序性 (禁止指令重排)
JMM(java内存模型)之可见性
JMM内存模型的可见性,只要有一个线程改变数据后要写回到主内存中,其它的线程马上就会知道主内存中的数据已经改变了。
及一个线程改变一个共享对象的内容,改变及时通知其他线程
volatile
volatile基本满足JMM的三个特性,除了原子性之外
volatile特性:
- 线程间可见性
- 不保证原子性
- 有序性 (禁止指令重排)
jmm缓存不一致性问题
volatile可见性底层实现原理
volatile不保证原子性
理论生是10x1000, 实际小于等于10x1000
volatile不保证原子性体现就在这
线程1修改num写回主内存时,触发cpu总线监听(但此时线程2也对num+1并assign到自己的工作内存),出发总线监听机制线程2就会重新从主内存中加载数据到自己工作内存,导师更才num+1并assign到自己的工作内存的数据失效,也就是导致一次++操作失效。最终就是导致数据小于10x1000