多线程核心:可见性和原子性(工作内存与主内存) 如下图:
所有的共享变量存在于主内存,每个线程独有自己的共享内存副本即工作内存。
com.prometheus.multiThread.day07
使变量在多个线程间可见,没有原子性,通过加入内存屏障和 禁止重排序(as if serial)优化实现可见性。
读也好,写也好都是基于对这个变量的加锁操作,全过程中变量是加锁的,其他线程无法对这个变量进行读写操作
参考 :
http://blog.csdn.net/lemon_tree12138/article/details/51062421
代public class VolatileDemo {
/**
* volatile只有可见性,无法保证原子性
*/
private volatile int num=0;
public int getNum() {
return this.num;
}
public void increase() {
try {
//休眠更容易重现结果不为500
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
this.num++;
}
public static void main(String[] args) {
final VolatileDemo volatileDemo = new VolatileDemo();
for (int i=0;i<500;i++){
new Thread(new Runnable() {
@Override
public void run() {
volatileDemo.increase();
}
}).start();
}
//如果还有子线程在执行,主线程让出cpu资源,直到子线程执行完毕,主线程继续执行
while (Thread.activeCount()>1){
Thread.yield();
}
System.out.println("-------num:"+volatileDemo.getNum());
}
}
若解决以上问题,可采用ReentrantLock解决 代码 com.prometheus.multiThread.day07.VolatileDemoReenTrantLock
com.prometheus.multiThread.day08
com.prometheus.multiThread.day10.ConnThreadLocal
github : https://github.com/liangliang1259/common-study.git