My java——JVM(内存域)三


续 My java——JVM(内存)二  写了一点JVM内存的一些操作的方法,和引出内存的分类。

    是呀,java内存是我们在java编程中很少考虑到的,也没用真正的管理过。也许都知道JVM有自己的垃圾回收机制,所以在编程中没有考虑过,的确JVM帮我们解决了在C++中最头痛的事情。但这里还是要抛出一点JVM内存的一点知识,以便明白java程序在JVM运行原理。
    关于JVM的内存有很多不同的说法和版本,,反正我是是弄混了的,在上篇博文中也提到存储的分类。也许是JVM有不同的版本吧,所以有很多不同的说法。

My java——JVM(内存域)三

从上图可以见到的看出分为五个部分,两个是线程共享区,三个线程隔离区。

 

 

PROGEAM COUNTER REGISTER
(程序计数器)

线程私有
指向下一条要很执行的指令

JAVA STACK
(虚拟机栈)

线程私有
存储局部变量表、操作栈、动态链接、方法出口

NATIVE METHOD STACK
(本地栈)

线程私有
为虚拟机使用到的
Native 方法服务

HEAP
(堆)

线程共享
所有的对象实例以及数组都要在堆上分配
回收器主要管理的对象

MEATHOD AREA
(方法区)

线程共享
非堆主要区域
存储类信息、常量、静态变量、即时编译器编译后的代码

1、程序计数器
    记录java线程的标记,可以简单理解成一个线程的ID,和记录该线程的运行状况。

2、JVM栈
    本地变量表存放了编译期可知的各种标量类型(boolean、byte、char、short、int、float、long、double)、对象引用(不是对象本身,仅仅是一个引用指针)、方法返回地址等。生命周期与线程的周期一样,线程解释,栈的内存就清空。

3、本地栈
    本地方法栈与VM栈所发挥作用是类似的,只不过VM栈为虚拟机运行VM原语服务,而本地方法栈是为虚拟机使用到的Native方法服务,所以可以理解成与java程序五个。

4、
    Java堆是虚拟机管理最大的一块内存,经常有人把Java 内存区分为堆内存(Heap)和栈内存(Stack),这种分法比较粗糙,Java 内存区域的划分实际上远比这复杂。这种划分方式的流行只能说明大多数程序员最关注的、与对象内存分配关系最密切的内存区域是这两块。这样分也让程序员更加清楚,String s = new String("mylove");等号前的存储在栈中,等号后的存储在堆中,这也许是一个简单的理解。JVM内存回收主要就是回收堆的。通过-Xmx和-Xms控制的就是堆的大小。

5、方法区
    方法区中存放了每个Class的结构信息,包括常量池、字段描述、方法描述等等。VM Space描述中对这个区域的限制非常宽松,除了和Java堆一样不需要连续的内存,也可以选择固定大小或者可扩展外,甚至可以选择不实现垃圾收集。相对来说,垃圾收集行为在这个区域是相对比较少发生的,但并不是某些描述那样永久代不会发生GC(至少对当前主流的商业JVM实现来说是如此),这里的GC主要是对常量池的回收和对类的卸载,虽然回收的“成绩”一般也比较差强人意,尤其是类卸载,条件相当苛刻。

非运行时内存区:

6、运行常量池
    Class文件中除了有类的版本、字段、方法、接口等描述等信息外,还有一项信息是常量表(constant_pool table),用于存放编译期已可知的常量,这部分内容将在类加载后进入方法区(永久代)存放。但是Java语言并不要求常量一定只有编译期预置入Class的常量表的内容才能进入方法区常量池,运行期间也可将新内容放入常量池(最典型的String.intern()方法)。

7、直接内存
    直接内存并不是虚拟机运行时数据区的一部分,它根本就是本机内存而不是VM直接管理的区域。

参考:http://blog.sina.com.cn/s/blog_67fdef9001011nyv.html

你可能感兴趣的:(My java——JVM(内存域)三)