JVM的内存区域划分

目录

1、程序计数器(内存中最小的一块,里面保存了当前线程下一条执行的指令的地址)

2、栈(保存局部变量和方法调用的信息)?

[3、堆 (成员变量和new出来的对象都在堆上)](#3、堆 (成员变量和new出来的对象都在堆上))

4、方法区(存储常量,静态变量,类对象等等)?

总结:JVM内存区域划分?


JVM的内存区域划分分为四个区域:程序计数器,栈,堆,方法区(现在也叫元数据区)。

1、程序计数器(内存中最小的一块,里面保存了当前线程下一条执行的指令的地址)

每个线程只有一个程序计数器,所以每个程序计数器是线程私有的。操作系统是以线程为单位调度的,所以每个线程都需要记录自己当前执行到哪一步了,以便后续再次调用。

2、栈(保存局部变量和方法调用的信息)

栈也是线程私有的,在我们调用方法的时候,每调用一个方法,该方法就会进入栈中,当该方法执行完毕的时候就会从栈中移除。

比如说现在要在main方法中调用A方法,在A方法中再调用B方法:

但是,如果我们不停的调用方法,就会导致栈满,这样就会出现栈满了的报错信息。这种现象尤其是在递归的时候容易出现。

每一个线程都有一个栈,每个栈都是线程私有的。

栈中还有个比较特殊的叫做本地方法栈,这个栈是存放native方法的,比如hashCode(),同样是线程私有的。

3、堆 (成员变量和new出来的对象都在堆上)

堆是属于线程共享的,只有一个堆的存在。成员变量和new出来的对象都在堆上,所以堆也是内存中最大的一块空间。需要注意的是,new出来的对象是在堆上,但是对new出来的对象的引用却是在栈上面的。

4、方法区(存储常量,静态变量,类对象等等)

方法区也是线程共享的,方法区存放了类对象,以及该类的静态属性,运行时常量池(JDK8之前。JDK8移到堆中了),类属性等等 。

运行时常量池中包含字面量和符号引用

字面量 : 字符串、final常量、基本数据类型的值。

符号引用 : 类和结构的完全限定名、字段的名称和描述符、方法的名称和描述符。

总结:JVM内存区域划分

相关推荐
sniper_fandc2 分钟前
SpringMVC详解
java·springmvc
Gyoku Mint10 分钟前
深度学习×第4卷:Pytorch实战——她第一次用张量去拟合你的轨迹
人工智能·pytorch·python·深度学习·神经网络·算法·聚类
葫三生1 小时前
如何评价《论三生原理》在科技界的地位?
人工智能·算法·机器学习·数学建模·量子计算
TT哇1 小时前
【Java EE初阶】计算机是如何⼯作的
java·redis·java-ee
拓端研究室3 小时前
视频讲解:门槛效应模型Threshold Effect分析数字金融指数与消费结构数据
前端·算法
随缘而动,随遇而安5 小时前
第八十八篇 大数据中的递归算法:从俄罗斯套娃到分布式计算的奇妙之旅
大数据·数据结构·算法
IT古董6 小时前
【第二章:机器学习与神经网络概述】03.类算法理论与实践-(3)决策树分类器
神经网络·算法·机器学习
Fireworkitte8 小时前
Apache POI 详解 - Java 操作 Excel/Word/PPT
java·apache·excel
weixin-a153003083168 小时前
【playwright篇】教程(十七)[html元素知识]
java·前端·html
DCTANT8 小时前
【原创】国产化适配-全量迁移MySQL数据到OpenGauss数据库
java·数据库·spring boot·mysql·opengauss