volatile分析

volatile三大特性: 1. 内存可见性 2.不保证原子性 3. 禁止重排序
内存屏障的概念:
memory barrier是一个CPU指令。
指令逻辑:a.确保一些特定操做执行顺序 b.影响一些数据的可见性
编译器和CPU能够在保证输出结果同样的状况下对指令重排序,使性能获得优化。
插入一个内存屏障,至关于告诉CPU和编译器先于这个命令的必须先执行,后于这个命令的必须后执行。
内存屏障另外一个做用是强制更新一次不一样CPU的缓存。例如:一个写屏障会把这个屏障前写入的数据刷新到缓存,
这样任何试图读取该数据的线程将获得最新值,而不用考虑究竟是被那个CPU核心或者那个CPU执行。
memory barrier和volatile的关系?上面的虚拟机指令里面提到的,若是你的字段是volatile,java内存模型将在
写操做后插入一个写屏障指令,在读操做前插入一个读屏障指令。
若是对volatile字段进行读写操做,必须知道1.一旦写完成,任何访问这个字段的线程将会获得最新的值
2.在写入前,会保证全部以前发生的事已经发生,而且任何更新过的数据值也是可见的,由于内存屏障会把
以前的写入值都刷新到缓存。java

样例1缓存

class TestData{
    //int count = 0;
    volatile int count = 0;
    public void Data(){
        this.count = 10;
    }
}
public class VolatileTest {
    public static void main(String[] args){
        TestData td = new TestData();
        new Thread(()-> {
            System.out.println(Thread.currentThread().getName() + "  " + td.count);
            try {
                TimeUnit.SECONDS.sleep(4);
                td.Data();
                System.out.println(Thread.currentThread().getName() + "  " + td.count);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        },"banana").start();

        while (td.count == 0){

        }

        System.out.println(Thread.currentThread().getName() + "  " + td.count);
    }
}
相关文章
相关标签/搜索