zoukankan      html  css  js  c++  java
  • Java多线程volatile关键字

    JVM中,分为JVM Client模式,JVM Server模式。两者区别并不大,但serve启动模式启动较慢,但一旦运行起来后,在hash和method call方面的效率,比Client模式效率高数十倍。

    线程在读取数据时,首先从主内存中读取数据,保存在本地工作内存中,然后对数据进行修改,修改完毕后,写入本地工作内存中,再从工作内存写入主内存。示例图如下:

    JVM如果以Server模式启动时,为了线程的效率,线程在第一次读取数据后,将数据保存在工作内存中,之后读取数据时,均从工作内存中读取。但如果主内存修改了数据,则会导致工作内存的数据与主内存数据不一致。导致逻辑错误。

     

    volatile关键字只可以修饰变量。当用volatile对某一个变量进行修饰后,每次读取变量均强制要求从主内存中读取,这样可以保证变量的一致性。保证数据的可见性,但并不能保证数据的原子性。

     

  • 相关阅读:
    Daily Scrum 10.31
    Daily Scrum 10.30
    Daily Scrum 10.29
    Daily Scrum 10.28
    扩展设置
    安装
    james+javamail入门
    解决ZF2_PATH environment
    Apache Httpd Server 2.2升级2.4
    缓存,spring
  • 原文地址:https://www.cnblogs.com/CloudStrife/p/7151333.html
Copyright © 2011-2022 走看看