zoukankan      html  css  js  c++  java
  • volatile分析

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

    样例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);
        }
    }
  • 相关阅读:
    从yum源下载软件包
    本地yum源建立
    Redis慢查询,redis-cli,redis-benchmark,info
    Centos6.6安装mysql记录
    Nginx常用命令(加入系统服务)
    Nginx+keepalived双机热备(主从模式)
    Nginx反向代理+负载均衡简单实现
    Centos7安装Python3.5
    CentOS 6.4下OpenSSH升级到6.7操作
    Redis详解
  • 原文地址:https://www.cnblogs.com/mutong1228/p/10725773.html
Copyright © 2011-2022 走看看