问题背景 (下面的所有内容都是根据书上的Serial/Serial Old收集器下的情况) 在<深入理解JVM>一书中的——3.6.3长期存活的对象将进入老年代的介绍中, 一个例子的jvm参数中加了这一行 -XX:+printTenuringDestribution 意思是希望每次新生代gc后,可以跟踪Survivor区中的对象的年龄分布. 然后还设置了 -XX:MaxTenuringThreshole= 这是晋升老年代的年龄阈值. 然后在gc日志中,出现了这样的字眼: [GC [DefNew…
实验一: 存活对象包含 小于survivor大小的对象 + 大于survivor的对象 private static final Integer _1MB = 1024 * 1024; /** * -XX:+UseSerialGC -Xms20M -Xmx20M -Xmn10M -XX:+PrintGCDetails * eden=8m survivor=1m old=10m * @param args */ public static void main(String[] args) { by…
Major GC 是清理老年代. Full GC 是清理整个堆空间—包括年轻代和老年代.…
堆里面分为新生代和老生代(java8取消了永久代,采用了Metaspace),新生代包含Eden+Survivor区,survivor区里面分为from和to区,内存回收时,如果用的是复制算法,从from复制到to,当经过一次或者多次GC之后,存活下来的对象会被移动到老年区,当JVM内存不够用的时候,会触发Full GC,清理JVM老年区 当新生区满了之后会触发YGC,先把存活的对象放到其中一个Survice区,然后进行垃圾清理.因为如果仅仅清理需要删除的对象,这样会导致内存碎片,因此一般会把E…
代码: public static string GetLoggingString(this object obj) { using (var stream = new MemoryStream()) { new XmlSerializer(obj.GetType()).Serialize(stream, obj); stream.Position = ; var buffer = new byte[stream.Length]; stream.ReadAsync(buffer, , buffe…
首先查看服务器版本默认信息: 修改tomcat/bin/catalina.sh,在最顶端加入JAVA_OPTS="$JAVA_OPTS -XX:+PrintGCDetails -Xloggc:/usr/local/java/apache-tomcat-7.0.78/bin/gc.log" 随后在 -Xloggc指定路径下,打开gc.log,部分信息如下: Java HotSpot(TM) 64-Bit Server VM (25.144-b01) for linux-amd64 JRE…
JVM中的堆,一般分为三大部分:新生代.老年代.永久代: 1 新生代 主要是用来存放新生的对象.一般占据堆的1/3空间.由于频繁创建对象,所以新生代会频繁触发MinorGC进行垃圾回收. 新生代又分为 Eden区.ServivorFrom.ServivorTo三个区. Eden区:Java新对象的出生地(如果新创建的对象占用内存很大,则直接分配到老年代).当Eden区内存不够的时候就会触发MinorGC,对新生代区进行一次垃圾回收. ServivorTo:保留了一次MinorGC过程中的幸存者.…
名词解释: GC:垃圾收集器 Minor GC:新生代GC,指发生在新生代的垃圾收集动作,所有的Minor GC都会触发全世界的暂停(stop-the-world),停止应用程序的线程,不过这个过程非常短暂. Major GC/Full GC:老年代GC,指发生在老年代的GC. JVM:Java Virtual Machine(Java虚拟机)的缩写. 正文: >堆 众所周知,所有通过new创建的对象的内存都在堆中分配,堆被划分为新生代和老年代,新生代又被进一步划分为Eden和Survivor区…
JVM中的堆一般分为三大部分:新生代.老年代.永久代,其大致的占比如下:  一.新生代 新生代主要用来存放新生的对象.一般占据堆空间的1/3.在新生代中,保存着大量的刚刚创建的对象,但是大部分的对象都是朝生夕死,所以在新生代中会频繁的进行MinorGC,进行垃圾回收.新生代又细分为三个区:Eden区.SurvivorFrom.ServivorTo区,三个区的默认比例为:8:1:1. Eden区:Java新创建的对象绝大部分会分配在Eden区(如果对象太大,则直接分配到老年代).当Eden区内存不…
参考资料: http://blog.csdn.net/flamezyg/article/details/44673951 http://www.blogjava.net/ldwblog/archive/2013/07/24/401919.html http://www.360doc.com/content/12/1023/16/9615799_243296263.shtml   JVM中的堆,一般分为三大部分:新生代.老年代.永久代: 一:新生代:主要是用来存放新生的对象.一般占据堆的1/3空间…