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

        运行时常量池是方法区的一部分,具有动态性,即运行时也可以将新的常量放入池中



简单分享一下自己学习时制作的思维导图:

JVM内存管理机制_第1张图片

        




你可能感兴趣的:(JVM内存管理机制)