04、JVM运行时几个重要内存区域

程序在运行的时候,数据具体会在JVM提供的这几个内存区域中进行数据交互。

程序运行的时候有对应的class源文件数据,代码的编译信息等需要地方存储,这个就是MethodArea(方法区/元数据区)

然后线程跑起来之后需要有存线程相关信息的地方,这个就是JVMStacks

同时也需要一个记录程序执行位置的空间,这个就是ProgramCounter

还有对于线程来说还需要一些高效率或跟底层硬件联系的类库,这些数据就存放在本地方法栈(Native Method Stacks)

程序跑的时候往往不是单个线程的,在多线程跑的时候,就需要有共享的内存,这个就是堆区(Heap)

对于追求性能的程序来说,可能还需要用到堆外内存,这部分就是直接内存区(DirectMemory)

1、MethodArea

2、JVMStacks

3、ProgramCounter

4、NativeMethodStacks

5、Heap

6、DirectMemory

  • MethodArea:存放了class的源信息,也包括了常量池中的数据

  • JVMStacks:方法栈,它是每个线程私有的,主要有如下内容

    • Local Variable Table(本地变量表)
    • Operend Stacks(操作数栈)
    • Dynamic Linking(动态链接)
    • Return Address(方法最后返回值存放地址)

    方法栈主要保证程序中的方法能正常运行而设计的,既然如此,它肯定会有用来存方法中局部变量的空间也就是Local Variable Table(本地变量表),同时数据的交换和计算需要一个栈来作为数据计算的容器,同时方法中肯定需要访问其他的非局部的变量,此时如何找到它们,就需要Dynamic Linking来处理了,最后有些方法是需要一个返回值的也就是Return Address

相关推荐
小宇的天下几秒前
Virtuoso 中的tech file 详细说明
java·服务器·前端
WX-bisheyuange5 分钟前
基于SpringBoot的诊疗预约平台
java·spring boot·后端·毕业设计
SimonKing7 分钟前
基于Netty的WebSocket客户端
java·后端·程序员
DYS_房东的猫9 分钟前
《 C++ 零基础入门教程》第8章:多线程与并发编程 —— 让程序“同时做多件事”
开发语言·c++·算法
ekkcole13 分钟前
java实现对excel模版填充保存到本地后合并单元格并通过网络下载
java·开发语言·excel
Zoey的笔记本16 分钟前
「软件开发缺陷管理工具」的闭环追踪设计与自动化集成架构
java·服务器·前端
setary030122 分钟前
c++泛型编程之Typelists
开发语言·c++
极客先躯23 分钟前
高级java每日一道面试题-2025年5月09日-基础篇[协议-注解-缓存]-JCache(JSR-107)是什么?它的主要目标是什么?
java·spring·缓存
u01040583623 分钟前
Java应用的链路追踪:实现分布式跟踪
java·开发语言·分布式
这是个栗子26 分钟前
【API封装参数传递】params 与 API 封装
开发语言·前端·javascript·data·params