线程A正在修改value。线程B正在读,这里读的就是过期的数据了。
只有给get,set同时加上同步才可以保证读到的不是过期数据。不明白,为什么get,set同时加上同步可以保证不出现这种情况?
继续往下看,好像明白一点,共享变量在公共的锁中是相互可见的。
java 多线程 并发
加了同步也不能保证读到非过期的数据,问题不在这里。同步的作用是不会读到不完整的数据,这才是互斥的原因,int的更新未必是原子操作。
JAVA中synchronized的疑问?
这段java多线程代码有问题吗?
并发重复数据问题
【疑惑】Java多线程与操作系统的“用户级线程”/“核心级线程”
MongoDB 2.6 的 Bulk API
Java终止线程问题