Java volatile

 

 

 

1、线程有自己的独立的内存  对于共享变量会从主内存复制一份到自己线程的内存

 

2、一个线程里修改了共享变量 两个线程里是看不到的

 

3、使用 volatile 修饰后 ,线程每次修改了 变量 会写到主内存,读取该变量时直接从主内存读取

 

4、volatile 解决了 线程间的可见性  但是不能保证原子性

 

5、测试对共享变量 i   使用两个线程各 i++ 5000次    会发现多数测试结果不是 10000

     i++ 不是原子操作:实际是分为三步   从主内存读取、加1、写入主内存

    线程1  从主内存 读取i=0  然后阻塞住

    线程2 从主内存读取 i   这时读取到的是0   因为线程1阻塞了并没有修改i

    线程1  把i+1   i在线程1中值为1

    线程2  把i+1   i在线程2中值为1

    线程1  把i=1  写入主内存

    线程2  把i=1  写入主内存

    最后结果 两个线程执行了2次 ++  最后主内存的状态是 1 

    出现这种情况的根本原因就是 volatile 不能保证原子性

 

 

 

 

 

你可能感兴趣的:(杂七杂八,java)