`
collegeyuan
  • 浏览: 31451 次
  • 性别: Icon_minigender_2
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

JVM 新生代老年代

 
阅读更多
摘要: 堆设置 -Xms :初始堆大小 -Xmx :最大堆大小 -XX:NewSize=n :设置年轻代大小 -XX:NewRatio=n: 设置年轻代和年老代的比值。如:为3,表示年轻代与年老代比值为1:3,年轻代占整个年轻代年老代和的1/4 -XX:SurvivorRatio=n :年轻代中Eden区与两个Survivor区的比值。注意Survivor区有两个。如:3,表示Eden:Survivor=3:2,一个Survivor区占整个年轻代的1/5 -XX:MaxPermSize=n :设置持久代大小 收集器设置 -XX:+UseSerialGC :设置串行收集器 -XX:...

1. Java堆中各代分布:

图1:Java堆中各代分布

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

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

Permanent:是指内存的永久保存区域,主要存放Class和Meta的信息,Class在被 Load的时候被放入PermGen space区域. 它和和存放Instance的Heap区域不同,GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理,所以如果你的APP会LOAD很多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):

图2:GC参数

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

 

6. 例子:Heap size 设置

场景:在JAVA_HOME下demo/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,而-Xmn为1/4的-Xmx值。

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

 

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

图3:JVM运行时数据区(一)

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

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

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

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

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

 

图4:JVM运行时数据区(二)

Heap和Method area被所有线程共享,其生存期和JVM的生存期相同;Java Stacks、Pc registers、Native method stacks被每个线程独自拥有,其生存期和线程的生存期相同。

 

 

 

8. 常见的内存泄露错误

很多开发人员都碰到过java.lang.OutOfMemoryError的错误。这种错误又分两种:java.lang.OutOfMemoryError: Java heap space和java.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

5、http://www.precisejava.com

 

GC (minor )日志 
Full GC 日志
-verbose:gc -Xms20M -Xmx20M -Xmn10M -XX:SurvivorRatio=8 -XX:-HandlePromotionFailure -XX:+PrintHeapAtGC -XX:+PrintGCTimeStamps 
 -XX:+PrintGCDetails -XX:+PrintTenuringDistribution
分享到:
评论

相关推荐

    Java新生代老年代的划分及回收算法

    通过调整JVM参数,比如新生代和老年代的比例、Survivor区的大小、MaxTenuringThreshold等,可以优化垃圾回收的性能,减少垃圾回收带来的系统停顿时间,提升应用程序的整体运行效率。此外,合理的内存分配和对象管理...

    JVM内存模型架构图-新生代-老年代-永久代

    JVM内存模型架构图,核心部分包括: GC主要在新生区(伊甸园区)、老年区 新生区(伊甸园区(对象都是在这个区new出来的)、幸存区to、幸存区from:幸存区位置会互相交换,谁空谁是to) 老年区 永久区:存储的是...

    JVM调优与内存管理总结

    JVM内存主要分为新生代、老年代和持久代,每个区域都有其特定的垃圾回收策略。 1. 引用计数法(Reference Counting):这是一种简单的垃圾回收算法,但无法处理循环引用,容易导致内存泄漏。 2. 标记-清除法(Mark...

    jvm paper jvm

    1. 堆(Heap):所有对象都在堆中分配内存,是线程共享的区域,分为新生代和老年代。 2. 新生代(Young Generation):新生代进一步划分为Eden区和两个Survivor区(From空间和To空间)。大部分对象在Eden区创建,...

    JVM工作原理学习笔记

    JVM使用不同算法对堆内存进行垃圾回收,如新生代的复制算法、老年代的标记-整理算法或标记-清除算法。垃圾回收的目标是回收不再使用的对象,以释放内存空间。此外,JVM还提供了垃圾收集器,如Serial、Parallel、CMS...

    JVM常见面试题解析.pdf

    3. 内存分代:JVM堆内存分为新生代、老年代和持久代(现为元空间)。新生代进一步划分为Eden和两个Survivor区(S0和S1),目的是通过复制算法减少GC时的对象移动,避免碎片化。默认情况下,新生代与老年代的比例为1:...

    jvm视频及笔记

    4. **垃圾收集**:JVM如何自动管理内存,理解不同垃圾收集器如Serial、Parallel、CMS、G1等的工作机制,以及新生代和老年代的概念。 5. **类加载器**:系统类加载器、扩展类加载器和应用程序类加载器之间的双亲委派...

    思维导图-详细了解JVM和GC过程

    JVM新生代采用此算法。 - **标记-整理(Mark-Compact)**:标记存活对象,然后将所有存活对象移动到一端,直接清理另一端。老年代常用此算法。 - **分代收集(Generational GC)**:根据对象生命周期特点,将...

    狂神说JVM探究.rar

    - 使用JVM参数进行性能优化,例如-Xms、-Xmx设定堆内存大小,-XX:NewRatio调整新生代与老年代比例。 - 调整GC策略,如选择G1、Parallel GC、CMS等。 7. **类加载器**: - Bootstrap ClassLoader、Extension ...

    monkey老师的jvm 调优

    1. **内存管理**:JVM内存分为堆内存和栈内存,其中堆内存又分为新生代、老年代和永久代(Java 8后改为元空间)。合理的设置各区域大小,如新生代与老年代的比例,可以有效避免垃圾收集频繁触发,提高应用响应速度。...

    JVM调优,GC算法汇总

    JVM调优涉及到许多方面,包括堆大小设置(新生代、老年代)、GC策略选择、元空间大小、栈深度等。调优的目标通常是为了平衡应用的响应速度、内存使用和系统资源的消耗。 - **新生代与老年代的大小调整**:新生代...

    jvm思维导图 .pdf

    堆被分为新生代(Young Generation)和老年代(Tenured Generation),新生代进一步细分为伊甸区(Eden Space)、两个幸存者区(From Space和To Space)。默认情况下,新生代占据堆的1/3,其中伊甸区占新生代的大...

    JVM调优总结(java)

    分代收集是现代JVM的主流策略,它将内存分为新生代和老年代,不同代的对象使用不同的垃圾回收策略。新生代主要处理短暂存活的对象,而老年代则负责长期存活的对象。这种策略能有效减少垃圾回收的暂停时间。 4. **...

    jvm gc

    5. **JVM调优**:通过调整JVM参数,可以控制GC的行为,例如设置堆大小、新生代和老年代的比例、GC策略等。常用的JVM参数有`-Xms`, `-Xmx`, `-Xmn`, `-XX:NewRatio`, `-XX:SurvivorRatio`, `-XX:+UseConcMarkSweepGC`...

    JVM调优实战.doc

    然后,通过对JVM参数的调整,比如改变堆大小、设置垃圾回收器类型、优化新生代和老年代的比例等,来提升系统的性能。 总结来说,JVM调优是提高Java应用性能的关键环节,涉及到对内存分配、垃圾回收策略、对象生命...

    JVM面试题资源

    - **JVM参数设置**:如-Xms、-Xmx设置堆大小,-XX:NewRatio控制新生代与老年代比例。 - **内存泄漏检测**:使用内存分析工具,如MAT (Memory Analyzer Tool)。 - **GC日志分析**:通过-XX:+PrintGC、-XX:+...

    JVM图解-JVM指令-JVM原型图.rar

    - 垃圾收集参数调整,例如设置新生代和老年代的比例,以优化不同应用的内存需求。 - 栈帧优化,如逃逸分析,帮助确定对象是否需要在堆上分配。 6. **JVM调优工具**: - JConsole和VisualVM提供可视化的监控和...

    精简版JVM总结.pdf

    堆被进一步划分为新生代、老年代,如Eden Space、Survivor Space和Tenured Gen。当堆空间不足时,无法分配新的实例,会导致OutOfMemoryError。 5. **方法区(永久代)**:存储虚拟机加载的类信息、常量、静态变量和...

Global site tag (gtag.js) - Google Analytics