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

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



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



        




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值