• Java多线程volatile关键字


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

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

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

     

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

     

  • 相关阅读:
    CMS、G1收集器
    一文入门Redis
    一文解析TCP/UDP
    ubuntu官方源
    一、单体架构分析
    netty简介2
    netty简介
    安装vmware tool
    jdk1.8安装(转载)
    HTTP1.0、HTTP1.1 和 HTTP2.0 的区别
  • 原文地址:https://www.cnblogs.com/CloudStrife/p/7151333.html
Copyright © 2020-2023  润新知