JVM 运行时数据区(二)
@
运行时数据区
JVM 运行时数据区主要分为5块
- 方法区 JDK1.8以后叫做元数据区(Metaspace)
- 堆区
- 虚拟机栈区
- 本地方法栈区
- 程序计数器
方法区和堆都是线程共享的,在JVM启动时创建,在JVM停止时销毁,而Java虚拟机栈、本地方法栈、程序计数器是线程私有的,随线程的创建而创建,随线程的结束而死亡。
subgraph 线程A
X((线程A))
C[虚拟机栈]
D[本地方法栈]
E[程序计数器]
end
subgraph 线程B
Y((线程B))
H[虚拟机栈]
I[本地方法栈]
J[程序计数器]
end
subgraph 线程共享区
K((线程共享))
A[方法区]
B[堆区]
end
X-->K
Y-->K
JDK1.7 -JVM运行时数据区
subgraph 物理内存
subgraph JVM
subgraph 共享区
A[方法区]
B[堆区]
end
subgraph 隔离区
C[虚拟机栈区]
D[本地方法栈区]
E[程序计数器]
end
end
end
JDK1.8 -JVM运行时数据区
subgraph 物理内存
subgraph JDK1.8 -JVM运行时数据区
B[堆区]
subgraph 非共享区域
C[虚拟机栈区]
D[本地方法栈区]
E[程序计数器]
end
end
A[元数据区]
end
共享区
在JVM运行时数据区中,方法区和堆区 是各个线程内共享的内存区域
堆区
堆区 主要是存储运行时创建的对象,以及运行时常量池对象等
方法区
方法区 主要存放类的信息,常量,静态变量,运行时常量池以及JIT编译后代码等,JDK1.7以后把常量池里面的对象存放到了堆中,方法区里面存放的时候其引用地址
隔离区
虚拟机栈
栈是一种数据结构,特点是FILO
每当启动一个新的线程后,java虚拟机都会为它分配一个java栈。java以栈帧为单位保存线程的运行状态。虚拟机只会对java栈执行2中操作,以栈帧我单位的入栈和出栈。
抛出的异常2种
- OutOfMemoryError 表述虚拟机空间不足,没法申请到空间
- StackOverflowError 线程请求的深度>大于虚拟机允许的深度
栈帧
栈帧部分组成:局部变量表,操作数栈,栈数据,动态链接,返回地址等。
subgraph 虚拟机栈
subgraph 栈帧
A[局部变量表]
B[操作数栈]
X((栈帧))
C[动态链接]
D[方法出口]
end
subgraph 栈帧
E[局部变量表]
F[操作数栈]
Y((栈帧))
H[动态链接]
I[方法出口]
end
X-->Y
end
- 局部变量用于保存函数的参数已经局部变量的引用,局部变量表中的变量只是在当前的函数中有效,当函数调用结束后,跟随着函数栈帧的销毁,局部变量表也会随之销毁。局部变量表在编译期间就确定了大小。局部变量表的存储单位是以Variable Slot 为最小的单位,每个变量槽都可以存储32位长度的内存空间。
- 操作数栈 主要用于保存计算过程中间结果,同时作为计算过程中变量临时存储。只支持出栈入栈的操作
- 动态链接 每个栈帧都包含一个指向运行时常量池中该栈帧的所属方法的引用,持有这个引用是为了支持方法调用过程中的动态链接,在类的加载阶段中的解析过程会将符号引用转化为直接引用,这种转化也称为静态解析。另外一部分将在运行时转化为直接引用,这个部分称之为动态链接
- 方法执行后 只有2中退出方法,一是方法返回指令,二是异常退出。
本地方法栈
这个个虚拟机栈一样,只不过这个是运行本地方法的内存模型。运行本地方法的时候也会去创建栈帧等一些列操作
程序计数器
程序计数器是一块较小的内存空间,维护着当先线程所执行的字节码行号,以便在CPU切换调度的时候能知道当先线程执行到了什么位置。如果当先线程正在执行本地方法(Native method)那么程序计数器是为空。
程序计算器主要有2个作用:
- 字节码的解释器可以通过修改程序计数器值来读取下一个指令,从而达到代码的流程控制,比如我们代码中创建的循环,异常处理等
- 在多线程的情况下,程序计数器是用来保持当前线程执行的位置,当CPU切换执行时间片,切换回来的时候任然能继续执行上次执行的位置
- 程序计数器 是唯一一个不会出现OOM的区域
JVM 运行时数据区(二)的更多相关文章
- JVM运行时数据区(二)
4.本地方法栈 本地方法栈与虚拟机栈所发挥的作用是非常相似的,它们之间的区别不过是虚拟机栈为虚拟机执行Java方法服务,而本地方法栈则为虚拟机使用到的Native方法服务. 与Java虚拟机栈一样本地 ...
- Jvm运行时数据区
一:运行时数据区 Java虚拟机在执行Java程序的过程中会把它管理的内存分为若干个不同的数据区域.这些区域有着各自的用途,一级创建和销毁的时间,有的区域随着虚拟机进程的启动而存在,有些区域则依赖用户 ...
- JVM运行时数据区和垃圾回收机制
最近参考各种资料,尤其是<深入理解Java虚拟机 JVM高级特性和最佳实践>,大牛之作.把最近学习的Java虚拟机组成和垃圾回收机制总结一下. 你不会的都是新知识,学无止境,每天进步一点点 ...
- Java内存管理:Java内存区域 JVM运行时数据区
转自:https://blog.csdn.net/tjiyu/article/details/53915869 下面我们详细了解Java内存区域:先说明JVM规范定义的JVM运行时分配的数据区有哪些, ...
- JVM 运行时数据区 (三)
JVM运行时数据区 运行时数据区由 程序计数器.java虚拟机栈.本地方法栈.堆.方法区 组成: 1.程序计数器 每一个Java线程都有一个程序计数器,用于保存程序执行到当前方法的哪一个指令,它是线程 ...
- JVM总结(一):概述--JVM运行时数据区
大三下,趁着寒假重温一遍JVM,准备在一个系列来总价一下学习JVM的整个过程.争取在接下来的一个星期内更新完这一个系列,然后回家过年. JVM运行时数据区 线程私有的数据区 程序计数器 虚拟机栈 本地 ...
- JVM运行时数据区与JVM堆内存模型小结
前提 JVM运行时数据区和JVM内存模型是两回事,JVM内存模型指的是JVM堆内存模型. 那JVM运行时数据区又是什么? 它包括:程序计数器.虚拟机栈.本地方法栈.方法区.堆. 来看看它们都是干嘛的 ...
- Jvm运行时数据区 —— Java虚拟机结构小记
关于jvm虚拟机的文章网上都讲烂了.尤其是jvm运行时数据区的内容. 抱着眼见为实的想法,自己翻了翻JVM规范,花了点时间稍微梳理了一下. 以下是阅读Java虚拟机规范(Java SE 8版)的第二章 ...
- Java中的字符串常量池和JVM运行时数据区的相关概念
什么是字符串常量池 JVM为了减少字符串对象的重复创建,其维护了一个特殊的内存,这段内存被成为字符串常量池或者字符串字面量池 工作原理 当代码中出现字面量形式创建字符串对象时,JVM首先会对这个字面量 ...
随机推荐
- Jbox弹窗控件无法获取子页面元素值得问题
top.$.jBox.open("iframe:${ctx}/report/reportSubjectDatabase/toChildWindow", "请选择重构快照表 ...
- 微信群里一道六年级数学题,求阴影面积,那我只能用python代码了
前言 文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取http ...
- 小L的直线
小学时期的小L发现自己很有艺术细胞,于是买了一块画板,但是他的绘画水平使得他只能连接两点画出一条线段.有一天他决定在一张有n个点的图上作画,即他可以把这n个点任意连接.大家认为平行线是非常不美观的,于 ...
- 关于MIME类型问题,浏览器请求到的资源是乱码
简介 我想很多同学都可能会遇到这样的问题,调用后台提共的静态资源服务api时,用浏览器打开发现却是一堆乱码.需要的是 JSON, 拿到的却是 xml,访问一个mp4的文件,浏览器直接下载.这一切的来源 ...
- amba H2平台用PWM控制LCD背光
ambarella H2系列Soc的GPIO口能作PWM使用的个数有限(GPIO0-GPIO3),从PRM里GPIO: Function Selection章节可以得到如何配置GPIO为PWM功能. ...
- ES6新增的 Set 和 WeakSet 是什么玩意?在此揭晓
现在的章节内容会更加的紧密,如果大家看不懂可以先去看以前的文章,当然看了的忘了,也可以去看一下,这样学习后面的内容才会更加容易. 什么是Set结构 Set是ES6给开发者带来的一种新的数据结构,你可以 ...
- php下载各种编辑器输出的内容到word中展示
<?php/** * Created by PhpStorm. * User: 工作 * Date: 2018/1/11 * Time: 12:02 */ //连接数据库$dsn = " ...
- 作业九——DFA最小化,语法分析初步
- udp协议与tcp协议
TCP协议与UDP协议支持的应用协议 TCP支持的应用协议主要有:Telnet.FTP.SMTP等: UDP支持的应用层协议主要有:NFS(网络文件系统).SNMP(简单网络管理协议).DNS(主域名 ...
- SpringBoot应用操作Rabbitmq
记录RabbitMQ的简单应用 1.springboot项目中引入maven包,也是springboot官方的插件 <dependency> <groupId>org.spri ...