JVM内存管理机制

运行时数据区域


Java Virtual Machine Stack

1. 线程私有(生命周期与线程相同)

2. Java方法执行内存模型:每个方法执行时会创建一个Stack Frame用于存储局部变量表、操作数栈、动态链接、方法出口等信息。每个方法从调用到执行完成的过程,就对应着一个Stack Frame在vm stack中入栈和出栈的过程。

Native Method Stack

1. 线程私有

2. 为native方法服务(Sun Hotspot虚拟机将native与vm stack合二为一)

Heap

1. 所有线程共享

2. 虚拟机启动时创建

3. 存放对象实例(唯一目的)

4. 垃圾收集主要区域

5. 主要采用分代收集算法,所以堆还可以细分为:新生代和老年代;

6. heap可悲多个线程划分出一部分私有的分配缓冲区(Thread Local Allocation Buffer, TLAB)

Method Area

1. 线程共享

2. 存储类信息、常量、静态变量、即时编译器编译后的代码





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值