JVM内存模型
2022-05-13 14:01:50 35 举报
java运行时数据区的内存模型
作者其他创作
大纲/内容
堆对象实例和数组
线程共享区
程序计数器虚拟机字节码指令的地址(行号)或 undifined
本地库接口Native Interface
本地方法栈Native 方法
线程独占区
垃圾回收器GarbageCollector
本地方法库Native Method Libraries
方法区(Methed Area):用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译后的代码等数据。
方法区类信息、常量、静态变量、即时编译后的代码
java 虚拟机栈Java 方法(局部变量、操作数栈、动态链接、方法出口)
JVM运行时数据区( Runtime Data Area)
Java 堆(Java Heap):Java 虚拟机中内存最大的一块,是被所有线程共享的,所有的对象实例和数组都在这里分配内存;
.Java 虚拟机栈(Java Virtual Machine Stacks):每个方法在执行的同时都会在Java 虚拟机栈中创建一个栈帧(Stack Frame)用于存储局部变量表、操作数栈、动态链接、方法出口等信息;栈帧就是Java虚拟机栈中的下一个单位
本地方法栈(Native Method Stack):与虚拟机栈的作用是一样的,只不过虚拟机栈是服务 Java 方法的,而本地方法栈是为虚拟机调用 Native 方法服务的;Native 关键字修饰的方法是看不到的,Native 方法的源码大部分都是 C和C++ 的代码
执行引擎(Execution Engine)
即时编译器JIT Compiler
程序计数器(Program Counter Register):当前线程所执行的字节码的行号指示器,字节码解析器的工作是通过改变这个计数器的值,来选取下一条需要执行的字节码指令,分支、循环、跳转、异常处理、线程恢复等基础功能,都需要依赖这个计数器来完成;为什么要线程计数器?因为线程是不具备记忆功能
0 条评论
下一页