探究JVM和GC

原创 2009年11月18日 15:54:00

 

1. Java堆中各代分布

1Java堆中各代分布

Young:主要是用来存放新生的对象。

Old:主要存放应用程序中生命周期长的内存对象。

Permanent:是指内存的永久保存区域,主要存放ClassMeta的信息,Class在被 Load的时候被放入PermGen space区域. 它和和存放InstanceHeap区域不同,GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理,所以如果你的APPLOAD很多CLASS的话,就很可能出现PermGen space错误。

 

2. JVM 使用的GC算法是什么?

分代收集。

即将内存分为几个区域,将不同生命周期的对象放在不同区域里;

GC收集的时候,频繁收集生命周期短的区域(Young area)

比较少的收集生命周期比较长的区域(Old area)

基本不收集的永久区(Perm area)

 

3. GC Full GC 有什么区别?

GC(或Minor GC):收集 生命周期短的区域(Young area)

Full GC (或Major GC):收集生命周期短的区域(Young area)和生命周期比较长的区域(Old area)

他们的收集算法不同,所以使用的时间也不同。 GC 效率也会比较高,我们要尽量减少 Full GC 的次数。 当显示调用System.gc() 时,gc does a full collection(both young generation and tenured generation).

 

4. Minor GC后,Eden是空的吗?

是的,Minor GC会把Eden中的所有活的对象都移到Survivor区域中,如果Survivor区中放不下,那么剩下的活的对象就被移到Old generation 中。

 

5. Garbage collection options(JDK1.4)

2GC参数

堆设置
-Xms :
初始堆大小
-Xmx :
最大堆大小
-XX:NewSize=n :
设置年轻代大小
-XX:NewRatio=n:
设置年轻代和年老代的比值。如:3,表示年轻代与年老代比值为13,年轻代占整个年轻代年老代和的1/4
-XX:SurvivorRatio=n :
年轻代中Eden区与两个Survivor区的比值。注意Survivor区有两个。如:3,表示EdenSurvivor=32,一个Survivor区占整个年轻代的1/5
-XX:MaxPermSize=n :
设置持久代大小
收集器设置
-XX:+UseSerialGC :
设置串行收集器
-XX:+UseParallelGC :
设置并行收集器
-XX:+UseParalledlOldGC :
设置并行年老代收集器
-XX:+UseConcMarkSweepGC :
设置并发收集器
垃圾回收统计信息
-XX:+PrintGC
-XX:+PrintGCDetails
-XX:+PrintGCTimeStamps
-Xloggc:filename
并行收集器设置
-XX:ParallelGCThreads=n :
设置并行收集器收集时使用的CPU数。并行收集线程数。
-XX:MaxGCPauseMillis=n :
设置并行收集最大暂停时间
-XX:GCTimeRatio=n :
设置垃圾回收时间占程序运行时间的百分比。公式为1/(1+n)
并发收集器设置
-XX:+CMSIncrementalMode :
设置为增量模式。适用于单CPU情况。
-XX:ParallelGCThreads=n :
设置并发收集器年轻代收集方式为并行收集时,使用的CPU数。并行收集线程数。

 

6. 例子:Heap size 设置

场景:在JAVA_HOMEdemo/jfc/SwingSet2/目录下执行下面的命令:

    java -jar -Xmn4m -Xms16m -Xmx16m SwingSet2.jar

系统输出:

Exception in thread "Image Fetcher 0" java.lang.OutOfMemoryError: Java heap space

Exception in thread "Image Fetcher 3" java.lang.OutOfMemoryError: Java heap space

Exception in thread "Image Fetcher 1" java.lang.OutOfMemoryError: Java heap space

Exception in thread “Image Fetcher 2” java.lang.OutOfMemoryError: Java heap space

调优:将-Xms-Xmx选项设置为32m,而-Xmn1/4-Xmx值。

结果:执行java -jar –Xmn8m –Xms32m -Xmx32m SwingSet2.jar,系统正常运行。

 

7. JVM  Runtime Data Area(运行时数据区):

3JVM运行时数据区()

Heap: JVM只有一个为所有线程所共享的堆,所有的类实例和数组都是在堆中创建的。

Method area: JVM只有一个为所有的线程所共享的方法区。它存储类结构,例如运行时常量池,成员和方法数据以及方法、构造方法的代码。

Java Stacks: 每个JVM线程拥有一个私有的栈。

Pc registers: JVM可以同时支持运行多个线程,因此每个线程需要各自的PC(program counter)寄存器。

Native method stacks: 保存native方法进入区域的地址 

 

4JVM运行时数据区()

HeapMethod area被所有线程共享,其生存期和JVM的生存期相同;Java StacksPc registersNative method stacks被每个线程独自拥有,其生存期和线程的生存期相同。

 

 

 

 

8. 常见的内存泄露错误

很多开发人员都碰到过java.lang.OutOfMemoryError的错误。这种错误又分两种:java.lang.OutOfMemoryError: Java heap spacejava.lang.OutOfMemoryError: PermGen space。引起这种错误的原因可能是程序问题,也可能是是JVM参数配置问题引起的。若是参数问题,前者可以同过配置-Xms-Xmx参数来设置,而后者可以通过配置 -XX:PermSize-XX:MaxPermSize来设置。

                            

9 参考资料:

 

1.  A brief history of garbage collection –

 

 

http://www-128.ibm.com/developerworks/java/library/j-jtp10283/

2.  Garbage collection in the HotSpot JVM –

http://www-128.ibm.com/developerworks/java/library/j-jtp11253/

3.  Tuning Garbage Collection with the 5.0 JavaTM Virtual Machine

http://java.sun.com/docs/hotspot/gc5.0/gc_tuning_5.html

4.  Diagnosing a GC problem –

http://java.sun.com/docs/hotspot/gc1.4.2/example.html

 

 

 

JVM结构、GC工作机制详解

题外话:最近在应聘阿里2015暑期实习,感触颇多。机会总是留给有准备的人的,所以平常一定要注意知识的巩固和积累。知识的深度也要有一定的理解,不比别人知道的多,公司干嘛选你?关于JVM和GC,我相信学j...
  • tonytfjing
  • tonytfjing
  • 2015年03月15日 16:48
  • 41337

JVM内存管理及GC机制

一、概述Java GC(Garbage Collection,垃圾收集,垃圾回收)机制,是Java与C++/C的主要区别之一,作为Java开发者,一般不需要专门编写内存回收和垃圾清理代码,对内存泄露和...
  • suifeng3051
  • suifeng3051
  • 2015年09月08日 16:28
  • 10608

JVM 之 GC日志分析

常用JVM参数 http://blog.csdn.net/gzh0222/article/details/8223277  分析gc日志后,经常需要调整jvm内存相关参数,常用参数如下 -Xm...
  • lan861698789
  • lan861698789
  • 2016年07月21日 17:53
  • 6847

Java JVM:垃圾回收(GC 在什么时候,对什么东西,做了什么事情)

在什么时候: 首先需要知道,GC又分为minor GC 和 Full GC(major GC)。Java堆内存分为新生代和老年代,新生代 中又分为1个eden区和两个Survior区域。 一般情况...
  • qq_33242819
  • qq_33242819
  • 2016年11月25日 11:17
  • 1583

jvm的GC日志分析

JVM的GC日志的主要参数包括如下几个: -XX:+PrintGC 输出GC日志 -XX:+PrintGCDetails 输出GC的详细日志 -XX:+PrintGCTimeStamps 输出G...
  • doc_sgl
  • doc_sgl
  • 2015年06月22日 16:37
  • 9577

聊聊JVM(一)相对全面的GC总结

最近时间比较紧张,要写的东西也有很多,只能想到一点写一点。关于GC,网上的资料太多,之前对一个系统调优的时候又回顾了一下,找了几篇广泛流传的资料,大部分都是大同小异,这里总个总结,希望能够做个相对的全...
  • ITer_ZC
  • ITer_ZC
  • 2014年12月05日 13:08
  • 13716

JVM之GC算法和种类

垃圾收集算法 可达性分析算法强引用StringReference 软引用SoftReference 弱引用WeakReference 虚引用PhantomReference 引用计数算法Referen...
  • qq_33938256
  • qq_33938256
  • 2016年09月11日 10:00
  • 292

jvm 常用调试工具和设置jvm GC方法和指令

JVM常用调试工具: jconsole – jconsole是基于JavaManagementExtensions (JMX)的实时图形化监测工具,这个工具利用了内建到JVM里面的JMX指令来提...
  • lxlmycsdnfree
  • lxlmycsdnfree
  • 2017年03月28日 23:42
  • 1150

JVM GC与频繁GC

1.JVM GC的内存管理 2.频繁 GC 的原因
  • sinat_25306771
  • sinat_25306771
  • 2016年08月20日 02:14
  • 3181

App主界面布局的实现方式(一)

RadioGroup + Fragment实现 01 效果图 该实现方式只能通过切换RadioButton来切换页面,并不能通过滑动来实现。 MainInterface.png ...
  • a214024475
  • a214024475
  • 2016年11月16日 16:47
  • 1339
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:探究JVM和GC
举报原因:
原因补充:

(最多只允许输入30个字)