Java虚拟机内存区域堆(heap)的管理
来源:互联网 发布:尔湾 知乎 编辑:程序博客网 时间:2024/05/23 15:28
在上一节中Java 出现内存溢出的定位以及解决方式 中对于Java虚拟机栈以及方法区的内存出现的异常以及处理方式进行了解析,因为Java虚拟机对于堆的管理十分复杂,而且Java虚拟机中最主要的内存区域,所以单独提出一节进行分析。
先来解释一下对象存活??
什么样的对象是已经死了的对象,需要垃圾回收器进行回收,这个概念至关重要,因为它影响到垃圾回收器对于哪一个对象进行回收。可以从GCRoot访问到的对象是存活的对象,那么以外的对象就是已死的对象。
GCRoot:包括四种 1)Java虚拟机栈中存放的reference指针指向的对象 2)本地方法栈中reference指向的对象 3)方法区中的常量引用对象 4)方法区中静态类属性引用的对象
GC 垃圾回收器
垃圾回收器采用的是标记-清除-整理算法回收内存。
Minor GC和Full GC,Minor GC是对年轻代回收的过程, Full GC 是对整个堆以及方法区进行回收的过程。
分代收集,在Java虚拟机中对于堆的内存区域进行再划分为,Young Generation(年轻代)和Old Generation(老代)
年轻代用于存储年龄没有达到-XX:PretenureSizeThreshold的对象,老代用于存储年龄超过了-XX:PretenureSizeThreshold的对象。
然后对于年轻代再进行细分,Eden Space, From Space, ToSpace三个内存区域,这三个内存区域的大小由-XX:SurivorRadio来定义。在进行Minor GC的时候,会将Eden Space和From Space中存活的对象Copy到ToSpace中,并将超过年龄的对象Copy到老代,当老代空间不足时,启动Full GC。
(上面概念只是进行了简单的描述,在JVM实际运行过程中要复杂的多,不过大概原理是这样的)。
了解了上面基本概念之后,看下面的垃圾回收器就比较简单了。垃圾回收器总共分为七种:Serial收集器与Serial Old收集器,Parallel Scavenge 收集器与Parallel Old,ParNew收集器,CMS收集器,G1(Garbage First)收集器。
1.Serial收集器与Serial Old收集器,分别用于收集年轻代和老年代内存区域,Serial是单线程的垃圾收集器,在运行过程中需要暂停所有的Java线程。
2.ParNew收集器实际上就是Serial收集器的多线程版本(针对于年轻代)。
3.Parallel Scavenge收集器与Parallel Old: 是并行的多线程垃圾处理器,可以规定最大垃圾收集停顿时间-XX:MaxGCPauseMillis以及设置吞吐量大小-XX:GCTimeRadio.
4.CMS收集器(Concurrent Mark Sweep): 是针对于老年代的多线程并发执行的垃圾回收器。以获取最短回收停顿时间为目标的收集器(主要用于B/S架构的服务器上)
5.G1(Garbage First)收集器: 是最新的垃圾回收器,适合于(JDK1.6_update14)以上的JVM;G1将整个Java堆(包括新生代和老年代)划分为多个固定大小的独立区域,并且跟踪这些区域里面的垃圾堆积程度,在后台维护一个垃圾优先列表,每次根据允许收集的时间,优先回收垃圾最多的区域。
总之,要想获得最大吞吐量的服务类型就采用Parallel Scavenge 收集器与Parallel Old收集器组合。要实现实时系统最好采用CMS 收集器(Concurrent Mark Sweep)。不过客户端由于比较小,还是使用Serial比较好。
- Java虚拟机内存区域堆(heap)的管理
- Java虚拟机-内存区域,堆,栈
- Java虚拟机--内存管理区域的深入学习笔记
- Java虚拟机的内存区域
- Java虚拟机内存的堆区(heap),栈区(stack)和静态区(static/method)
- Java虚拟机内存的堆区(heap),栈区(stack)和静态区(static/method)
- Java虚拟机内存的堆区(heap),栈区(stack)和静态区(static/method)
- Java虚拟机内存的堆区(heap),栈区(stack)和静态区(static/method)
- Java虚拟机内存的堆区(heap),栈区(stack)和静态区(static/method)
- java虚拟机内存的堆区(heap),栈区(stack)和静态区(static/method)
- java虚拟机内存的堆区(heap),栈区(stack)和静态区(static/method)
- Java虚拟机内存的堆区(heap),栈区(stack)和静态区(static/method)
- Java虚拟机内存的堆区(heap),栈区(stack)和静态区(static/method)
- 简述Java虚拟机内存的堆区(heap),栈区(stack)和静态区(static/method)
- Java虚拟机内存的堆区(heap),栈区(stack)和静态区(static/method)
- Java虚拟机内存——栈、堆、Non-heap
- Java虚拟机_内存管理_内存区域
- Java虚拟机内存区域
- 谈黑客
- 关于之前对#pragma pack ()误解的纠正
- ios7 uitableview 上面的空白处理
- WireShark分析TCP协议
- Motivation: WebBrowser control for MWF
- Java虚拟机内存区域堆(heap)的管理
- Css hacker for ie6、ie7、firefox
- CodeChef - Small factorials
- Latex学习7: matrices
- Java JDBC下执行SQL的不同方式executeQuery/executeUpdate/execute
- 2014.09.29
- 专题四:自定义Web浏览器
- 内部类 内部类的访问 匿名内部类
- POI导入导出