当前位置:网站首页>JVM 运行时数据区与JMM 内存模型详解
JVM 运行时数据区与JMM 内存模型详解
2022-08-01 08:14:00 【肥肥技术宅】
1. JVM 运行时数据区
JVM运行时数据区可以分为元空间,堆,虚拟机栈,本地方法栈,程序计数器五大块。

- 元空间(方法区):存放类模版对象,是线程共享的区域,在磁盘上,一般不会GC
- 堆空间:线程共享的区域,对象创建与GC的主要阵地
- 虚拟机栈:线程私有的,基本组成单位是栈帧,每个栈帧对应一个方法,栈帧组成如下
- 局部变量表:存放方法变量信息
- 操作数栈:方法运行的区域
- 动态链接:指向方法模板对象,与虚方法表一起实现方法重写
- 返回地址:方法的返回地址
- 本地方法栈:线程私有,本地方法的执行区域
- 程序计数器:线程私有,负责在线程上下文切换的过程中记录线程执行到了哪个位置
2. JMM 内存模型
硬件内存模型

通常情况下,当CPU需要读取主存时,它会将主存的部分读到CPU缓存中或者内部寄存器中,然后在寄存器中执行操作。当CPU需要将结果写回到主存中去时,它会将内部寄存器的值刷新到缓存中,然后在某个时间点将值刷新回主存。
在多处理器系统中,每个处理器都有自己的高速缓存,而它们又共享同一主内存,因此就会存在缓存一致性问题。为了解决一致性的问题,需要各个处理器访问缓存时都遵循一些协议,在读写时要根据协议来进行操作,这类协议有MSI、MESI等。
JMM
JMM内存模型将内容分为了线程私有内存与主内存两部分,其与我们之前提到的硬件内存模型的对应关系如下所示:

私有内存与主内存的交互由如下八种操作控制:

3. 可见行与 volatile 关键字
一言以蔽之,volatile 关键字通过内存屏障的形式来阻止指令重排,以维护变量的有序性与可见行。
一行代码到执行的过程中要经历以下的阶段:

volatile 关键字有如下两个作用:
- 保证被 volatile 修饰的共享变量对所有线程总是可见的,也就是当一个线程修改了被 volatile 修饰共享变量的值,新值总是可以被其他线程立即得知。
- 禁止指令重排序优化。
JVM中提供了四类内存屏障指令:
- loadload:两个读取操作之间
- storestore:两个写操作之间
- loadstore:读写操作之间
- storelosd:写读操作之间

边栏推荐
- LeetCode240+312+394
- Leetcode - 6135: the longest part of the figure
- gethostbyname \ getaddrinfo 解析域名IP地址不安全的原因
- 力扣周赛304 6135. 图中的最长环 内向基环树
- MySQL查询进阶——从函数到表连接的使用你还记得吗
- centos 安装php7.4,搭建hyperf,转发RDS
- The log causes these pits in the thread block, you have to prevent
- Golang: go get url and form attribute value
- Do I need to introduce any dependencies to write data to clickhouse using flinksql?
- Case practice --- Resnet classic convolutional neural network (Mindspore)
猜你喜欢

leetcode-6132: Make all elements in array equal to zero

小程序全面屏手势配置案例

Upgrade to heavyweight lock, lock reentrancy will lead to lock release?

Case practice --- Resnet classic convolutional neural network (Mindspore)

What do the values 1, 2, and 3 in nodetype mean?

special day to remember

Microsoft Azure & NVIDIA IoT 开发者季 I|Azure IoT & NVIDIA Jetson 开发基础

华为深度学习课程第九章——卷积神经网络以及案例实践

HoloView -- Tabular Datasets

自定义IP在PCIE中使用
随机推荐
JVM内存模型之深究模型特征
网络基础学习
VSCode 快捷键及通用插件推荐
What do the values 1, 2, and 3 in nodetype mean?
pytest interface automation testing framework | single/multiple parameters
pytest接口自动化测试框架 | parametrize叠加使用
pytest interface automation testing framework | skip test classes
MySQL query advanced - from the use of functions to table joins, do you remember?
Shell执行SQL发邮件
HoloView -- Tabular Datasets
Go supports OOP: use struct instead of class
SAP ABAP ALV+SMARTFORS 表分页 报表打印程序
zip package all files in the directory (including hidden files/folders)
LeetCode240+312+394
HoloView 在 jyputer lab/notebook 不显示总结
VoLTE基础学习系列 | 企业语音网简述
POJ1287联网题解
好的plm软件有哪些?plm软件排行榜
22牛客多校1 C.Grab the Seat (几何 + 暴力)
22 Grab the Seat 1 C.Grab the Seat (Geometry + Violence)