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 小时前
Spring Boot 敏感词过滤组件实现:基于DFA算法的高效敏感词检测与替换
java·数据库·spring boot·文本处理·敏感词过滤·dfa算法·组件开发
完全学不完2 小时前
JVM对象创建和内存分配
jvm
Coovally AI模型快速验证4 小时前
农田扫描提速37%!基于检测置信度的无人机“智能抽查”路径规划,Coovally一键加速模型落地
深度学习·算法·yolo·计算机视觉·transformer·无人机
pusue_the_sun4 小时前
数据结构:二叉树oj练习
c语言·数据结构·算法·二叉树
一叶飘零_sweeeet4 小时前
从繁琐到优雅:Java Lambda 表达式全解析与实战指南
java·lambda·java8
RaymondZhao344 小时前
【全面推导】策略梯度算法:公式、偏差方差与进化
人工智能·深度学习·算法·机器学习·chatgpt
艾伦~耶格尔5 小时前
【集合框架LinkedList底层添加元素机制】
java·开发语言·学习·面试
zhangfeng11335 小时前
DBSCAN算法详解和参数优化,基于密度的空间聚类算法,特别擅长处理不规则形状的聚类和噪声数据
算法·机器学习·聚类
一只叫煤球的猫5 小时前
🕰 一个案例带你彻底搞懂延迟双删
java·后端·面试
最初的↘那颗心5 小时前
Flink Stream API 源码走读 - print()
java·大数据·hadoop·flink·实时计算