JVM内存分析系列(三)JVM内存模型初步

本文深入解析Java虚拟机的数据区域组成,包括程序计数器、虚拟机栈、本地方法栈、方法区、堆和运行时常量池。重点阐述各部分的作用及内部机制。
根据《Java虚拟机规范(第二版)》的规定,结构如下

[img]http://dl2.iteye.com/upload/attachment/0093/2977/c73d13c2-cb01-3cd6-aca3-bdb12844465e.jpg[/img]

1)程序计数器
Program Counter Register
是一小块内存空间,他的作用是当前线程所执行的行号指示器。此内存区是唯一一个没有规定OutOfMemoryError情况的区域。

2)Java虚拟机栈
Java Virtual Machine Stack
生命周期与线程相同,,描述的是java方法执行的内存模型。每个方法被执行的时候都会创建一个栈帧。

3)本地方法栈
Native Method Stack
为虚拟机使用到的native方法服务。在Sun HotSpot中,把本地方法栈和虚拟机栈和二为一了。

4)方法区
Method Area
被所有线程共享的一块内存区,存放一被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。方法区和永久代本质上并不等价,HotSpot只是用永久代实现方法区而已。

5)堆
Heap
被所有线程共享的一块内存区,存放对象实例。

6)运行时常量池
Runtime Constant Pool
是方法区的一部分,用于存放编译器生成的各种字面量和符号。例如:String类的intern()方法

7)直接内存
Direct Memory
并不是虚拟机运行时数据区的一部分,它使用了Native函数库直接分配堆外内存。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值