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

相关推荐
子午3 分钟前
【2026原创】文本情感识别系统~Python+深度学习+textCNN算法+舆情文本+模型训练
python·深度学习·算法
Flash.kkl4 分钟前
递归、搜索与回溯算法概要
数据结构·算法
s09071364 分钟前
【MATLAB】多子阵合成孔径声纳(SAS)成像仿真——基于时域反向投影(BP)算法
算法·matlab·bp算法·合成孔径
Xの哲學4 分钟前
Linux Workqueue 深度剖析: 从设计哲学到实战应用
linux·服务器·网络·算法·边缘计算
好大哥呀6 分钟前
Java 中的 Spring 框架
java·开发语言·spring
计算机毕设指导66 分钟前
基于微信小程序技术校园拼车系统【源码文末联系】
java·spring boot·mysql·微信小程序·小程序·tomcat·maven
大道之简7 分钟前
SpringBoot自定义链路追踪
java·spring boot·spring
Charlie_lll7 分钟前
LibreOffice 实现 Word 转 PDF
java·spring boot·pdf·word
hhzz8 分钟前
Springboot项目中使用EasyPOI操作Excel(详细教程系列4/4)
java·spring boot·后端·spring·excel·poi·easypoi
sin_hielo10 分钟前
leetcode 3047
数据结构·算法·leetcode