JVM一:JVM内存区域划分

目录

1.为什么需要内存区域划分?

2.内存区域划分介绍

[2.1 Native Method Stacks(本地方法栈)](#2.1 Native Method Stacks(本地方法栈))

[2.2 JVM Stacks(虚拟机栈)](#2.2 JVM Stacks(虚拟机栈))

[2.3 Program Counter Register(程序计数器)](#2.3 Program Counter Register(程序计数器))

[2.4 Heap(堆区)](#2.4 Heap(堆区))

[2.5 Metaspace(元数据区)](#2.5 Metaspace(元数据区))

[2.6 原则](#2.6 原则)


1.为什么需要内存区域划分?

JVM的内存区域划分是指JVM在执行Java程序时,如何将其管理的内存划分为不同的数据区域,以便存储不同类型的数据,并配合代码的执行流程,确保系统的正确运行。

将JVM的内存区域比作一个城市的交通系统。堆(Heap)是城市中的主要停车场,用于停放车辆(对象实例)。方法区(Method Area)像是城市的规划局,存储着城市的蓝图和规划信息。程序计数器(Program Counter)可以看作是路口的交通信号灯,指示着交通的流向和下一步的动作。虚拟机栈(Stack)和本地方法栈(Native Method Stack)分别是城市的公交站和火车站,用于管理和调度交通工具的进出。

2.内存区域划分介绍

JVM是一个应用程序,要从操作系统这里申请内存,JVM根据需求把整个空间,分成几个部分,每个部分各自有不同的功能作用。

2.1 Native Method Stacks(本地方法栈)

  • 1.native表示为JVM内部的C++代码,就是给调用native方法(JVM内部方法)准备的栈空间;
  • 2.native方法之间的调用关系;

2.2 JVM Stacks(虚拟机栈)

  • 1.给Java代码使用的栈;
  • 2.存储的为方法之间的调用关系;
  • 3.整个栈空间内部,可以包含很多个元素(每一个元素表示一个方法),这里的每个元素,称为一个"栈帧",这个栈帧里包含这个方法的入口地址,方法参数,返回地址,局部变量等;

  • 4.值得注意的是:这里的栈不等同于数据结构中的栈,是一个通用的,更广泛的概念,这里的栈特指JVM上的一块内存空间;

  • 5.这里的栈不是只有一个,而是有很多个;每个线程都有一个,一个进程有N个。

2.3 Program Counter Register(程序计数器)

  • 1.记录当前线程执行哪个指令(很小的一块存一个地址),每个线程都有一份

2.4 Heap(堆区)

  • 1.整个JVM空间最大的区域,主要存储new出来的对象,类的成员变量也在堆上;
  • 2.一个进程只有一份,多个线程共用一个堆

2.5 Metaspace(元数据区)

  • 1.类对象,常量池,静态成员在这里

2.6 原则

  • 1.局部变量在栈上;
  • 2.普通成员变量在堆上;
  • 3.静态成员变量在元数据区上

以上就是JVM内存区域划分的简单介绍。

相关推荐
追随者永远是胜利者5 小时前
(LeetCode-Hot100)253. 会议室 II
java·算法·leetcode·go
~黄夫人~5 小时前
Linux 权限管理:用户组 + 特殊权限 + ACL 解析
linux·运维·计算机·学习笔记·权限管理
追随者永远是胜利者6 小时前
(LeetCode-Hot100)207. 课程表
java·算法·leetcode·go
yanghuashuiyue7 小时前
lambda+sealed+record
java·开发语言
盟接之桥7 小时前
盟接之桥EDI软件:API数据采集模块深度解析,打造企业数据协同新引擎
java·运维·服务器·网络·数据库·人工智能·制造
2501_907136827 小时前
离线工具箱 内含53个小工具
linux·服务器·网络
时空潮汐8 小时前
神卓N600 NAS身份核验功能深度解析
linux·运维·网络·神卓nas·神卓n600 pro·家庭轻nas
哈哈浩丶8 小时前
安卓系统全流程启动
android·linux·驱动开发
小李独爱秋8 小时前
模拟面试:用自己的话解释一下lvs的工作原理
linux·运维·面试·职场和发展·操作系统·lvs
HoneyMoose8 小时前
Spring Boot 2.4 部署你的第一个 Spring Boot 应用需要的环境
java