JVM 运行时数据区

JVM 运行时数据区,第1张

JVM 运行时数据区

不同JVM,运行时数据区略微有不同,但都会遵从 Java 虚拟机规范, Java 虚拟机规范规定的区域分为五部分:

1、Java 虚拟机栈(Java Virtual Machine Stacks)

存储局部变量表、 *** 作数栈、动态链接、方法出口等信息。

2、Java 堆(Java Heap)

虚拟机中内存最大的一块,是被所有线程共享的,几乎所有的对象实例都存储在堆内。

3、本地方法栈(Native Method Stack)

与虚拟机栈的作用一样,不同之处:虚拟机栈是服务 Java 方法的,而本地方法栈是为虚拟机调用 Native 方法服务的。

4、方法区(Methed Area)

存储已被虚拟机加载的类信息、常量、静态变量、即时编译后的代码等数据。

5、程序计数器(Program Counter Register)

当前线程所执行的字节码的行号指示器,字节码解析器的工作就是通过改变这个计数器的值,来选取下一条要执行的字节码指令;另外,分支、跳转、循环、异常处理、线程恢复等基础功能,都要依赖计数器完成。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5681404.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存