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内存区域划分

相关推荐
码路飞2 小时前
GPT-5.4 Computer Use 实战:3 步让 AI 操控浏览器帮你干活 🖥️
java·javascript
AI工程架构师3 小时前
通常说算力是多少 FLOPS,怎么理解,GPU和CPU为什么差异这么大
算法
祈安_3 小时前
Java实现循环队列、栈实现队列、队列实现栈
java·数据结构·算法
皮皮林55115 小时前
拒绝写重复代码,试试这套开源的 SpringBoot 组件,效率翻倍~
java·spring boot
归去_来兮16 小时前
拉格朗日插值算法原理及简单示例
算法·数据分析·拉格朗日插值
顺风尿一寸19 小时前
从 Java NIO poll 到 Linux 内核 poll:一次系统调用的完整旅程
java
程途知微19 小时前
JVM运行时数据区各区域作用与溢出原理
java
华仔啊21 小时前
为啥不用 MP 的 saveOrUpdateBatch?MySQL 一条 SQL 批量增改才是最优解
java·后端
千寻girling1 天前
Python 是用来做 AI 人工智能 的 , 不适合开发 Web 网站 | 《Web框架》
人工智能·后端·算法
xiaoye20181 天前
Lettuce连接模型、命令执行、Pipeline 浅析
java