您的位置:首页 > 编程语言 > Java开发

Java 虚拟机运行时数据区域相关功能总结(Java虚拟机涉及相关的内存管理)

2014-06-18 23:47 429 查看
程序计数器(Program Counter Register):

(1)      存放字节码的地址

(2)      唯一一个没有规定OutOfMemoryError的区域。

Java虚拟机栈(JVM Stack):

(1)      Java方法执行的内存模型:每个方法在执行时会创建一个“栈帧”(stack frame),栈帧用于存储局部变量表、操作数栈、动态链接、方法出口等信息。

(2)      局部变量表存放存放的内容:基本数据类型(boolean,byte,char,short,int,long,float,double),对象引用(reference类型),returnAddress类型(存放一条字节指令的地址)。

(3)      异常情况有两种:一、StackOverflowError异常,线程请求的栈深度超出虚拟机所允许的深度,二、如过Java虚拟机栈允许动态扩展,而且扩展之后无法申请到足够的内存来满足要求,就会抛出OutOfMemoryError异常。

本地方法栈(Native Method Stack):

(1)      功能同Java虚拟机栈,但是Java虚拟机栈为java方法服务,本地方法栈为Native方法服务。

(2)      同虚拟机栈一样,也有两种异常情况:StackOverflowError异常和OutOfMemoryError异常。

Java堆(Java Heap):

(1)      唯一目的:存放对象实例。(物理上可不连续,逻辑上连续即可)

(2)      异常:当堆中没有足够空间完成实例分配时会抛出OutOfMemoryError。

方法区(Method Area):

(1)      用于存储类信息、常量、静态变量、即时编译器编译后的代码。

(2)      异常:OutOfMemoryError

运行时常量池(Runtime Constant Pool):

(1)      运行时常量此属于方法区的一个部分:用于存放各种字面常量和符号引用。

(2)      异常:OutOfMemoryError。

直接内存(Direct Memory):

(1)      不属于Java虚拟机运行时数据区的一部分,也不是Java虚拟机规范中定义的内存区域。JDK1.4引入NIO类,可以使用Native函数库直接分配堆外内存,然后通过Java堆中的DirectByteBuffer对象作为这块内存的引用进行操作。(避免了数据在Java堆和Native堆中来回复制,提高性能)。

(2)      异常:OutOfMemoryError

参考书籍:《深入理解Java虚拟机》 周志明 著 机械工业出版社
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  Java 虚拟机编程