JVM内存管理机制
近段时间学习周老师的《深入理解Java虚拟机》,对于JVM的内存管理机制有了一定的了解。
学习后感觉对于之前学习Java时遇到的一些模棱两可的东西有了更深的理解,希望能给大家带来一点帮助,后续也会继续补充,完善。
以下是JVM内存区域的主要组成部分的简单介绍:
程序计数器 Program Counter Register
程序执行的顺序指示器
Java虚拟机栈 JavaVirtual Machine Stacks
存储方法;
每个方法在执行的同时都会创建一个栈帧(Stack Frame-),用于存储局部变量表,操作数栈,动态链接,方法出口等信息;
局部变量表存放了编译器可知的各种数据基本类型,对象引用(referece类型),returnAddress类型。局部变量表所需的内存空间在编译期间便完全确定;
本地方法栈 Native Method Stack
与虚拟机栈十分类似,但只服务于其他虚拟机的Native方法
堆 Heap
所有的对象实例,数据均在堆上分配;(但随着技术的发展,“所有的”也不在是那么绝对);
方法区 Method Area
存放类,常量,静态变量,即时编译器编译后的代码等信息
运行时常量池 Runtime Constant Pool
运行时常量池是方法区的一部分,具有动态性,即运行时也可以将新的常量放入池中
简单分享一下自己学习时制作的思维导图: