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存储的值写入到主内存的共享变量当中。

  • 相关阅读:
    项目目标文档
    河北省民间组织管理系统项目分析
    《探索需求》读书笔记一
    “花儿日记”项目总结
    2015年秋季个人阅读计划
    场景调研
    “数组最大值求和”结对情况
    课堂改进意见
    《梦断代码》阅读笔记三
    linux io 学习笔记(03)---共享内存,信号灯,消息队列
  • 原文地址:https://www.cnblogs.com/poptest/p/5210643.html
Copyright © 2011-2022 走看看