zoukankan      html  css  js  c++  java
  • 老李谈JVM内存模型

    老李谈JVM内存模型

     

    poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标。如果对课程感兴趣,请大家咨询qq:908821478,咨询电话010-84505200。

    JVM内存模型 - 主内存和线程独立的工作内存

    Java内存模型规定,对于多个线程共享的变量,存储在主内存当中,每个线程都有自己独立的工作内存,线程只能访问自己的工作内存,不可以访问其它线程的工作内存。工作内存中保存了主内存共享变量的副本,线程要操作这些共享变量,只能通过操作工作内存中的副本来实现,操作完毕之后再同步回到主内存当中。

    如何保证多个线程操作主内存的数据完整性是一个难题,Java内存模型也规定了工作内存与主内存之间交互的协议,首先是定义了8种原子操作:

    (1) lock:将主内存中的变量锁定,为一个线程所独占

    (2) unclock:将lock加的锁定解除,此时其它的线程可以有机会访问此变量

    (3) read:将主内存中的变量值读到工作内存当中

    (4) load:将read读取的值保存到工作内存中的变量副本中。

    (5) use:将值传递给线程的代码执行引擎

    (6) assign:将执行引擎处理返回的值重新赋值给变量副本

    (7) store:将变量副本的值存储到主内存中。

    (8) write:将store存储的值写入到主内存的共享变量当中。

  • 相关阅读:
    几个数之和----数组刷题
    单调栈刷题
    腾讯金融科技凉经
    mysql刷题
    链表类题目常用方法
    阿里云一面凉经
    腾讯TEG一面凉经
    腾讯软件开发-后台开发实习生-一面凉经
    剑指 Offer 19. 正则表达式匹配
    剑指 Offer 20. 表示数值的字符串
  • 原文地址:https://www.cnblogs.com/poptest/p/5210643.html
Copyright © 2011-2022 走看看