1。首先先看一下jvm运行是的数据区域有哪些,如下图:
2。运行是的数据区,主要有程序计数器,虚拟机栈,本地方法栈,方法区,堆。程序计数器,虚拟机栈,本地方法栈是线程隔离区,属于线程私有;方法区和堆是线程共享区,属于线程共享。
3。运行数据区的详细介绍
程序计数器:程序计数器占用很小的一块空间,可以看做当前线程所执行的字节码的行号指示器。
Java虚拟机栈:描述java方法执行的内存模型(每个方法执行时,会创建一个栈帧,用于存储局部变量表、操作数栈、动态链表、方法出口等信息),局部变量表主要有编译期可知的各种基本数据类型、对象引用类型(指向对象起始地址的指针)、returnAddress类型(指向一条字节码指令的地址)。
本地方法栈:与虚拟机栈很相似,区别在于虚拟机栈是为虚拟机执行java方法服务,本地方法栈是为虚拟机执行本地(Native)方法服务。
Java堆:虚拟机管理的最大内存区域,为所有线程共享的内存区域。主要的目标就是存放对象实例和数组,几乎所有的对象实例都存在堆上。同样java堆也是垃圾收集器管理的区域,因此也成为“GC堆”。从内存回收角度来说,java堆也分为新生代和年老代,再细致一点就是Eden空间、From Survivor 空间、To Survivor空间等。
方法区:主要存储已被虚拟机加载的类信息、常量、静态变量、即时编译期编译的代码等。
运行常量池:方法区中的一部分,有类的模板、字段、方法、接口等信息和常量池,常量池中存放类加载后的字面量和符号引用。
相关的word文档:http://download.csdn.net/detail/u011359903/9865551