介绍
收集器很好的文章:https://blog.csdn.net/smartbetter/article/details/80561284
调优总结:https://www.iteye.com/blog/unixboy-174173
-------------------------43------------------------------------------------
对象优先在Eden分配。
选用哪些收集器是根据JDK的环境决定的。
在这里看JDK所处的环境,看到默认是Server的。
Eden区域
指定堆内存的大小。Serial垃圾收集器是复制算法新
指定新生代内存大小。-Xmn
新生代分为一块Eden和两块Servivor区域。
指定Eden的大小
-XX:SurvivorRatio=8
按照以上的参数运行:
2M 2M 2M|4M
可以看出第一个分配是4M第二个老年代分配为6M
原理: 2 2 2|4 8M放不下了,发生了一次GC操作。
第一个是发生在新生代的,时间短。第二个是发生在老年代的,时间长。
放不开放入Survivor。Survivor也放不下了。
直接根据内存分配担保放在了老年代了。------------------------------------------************
-----------------------44----------------------------------------------------------
大对象直接进入老年代:
指定参数:
此时7M没有进入老年代的。
修改参数设置大对象的值:
进入了老年代。
---------------------------45------------------------------------------------------
长期存活的对象进入老年代:
第一次gc将Eden复制到surivior。
年龄计数器:Age1+++++++++++++++
达到15(默认)进入到老年代中,不一定。
设置参数一般没到就进去了。
-------------------46-------------------------------------------------------------
这个参数禁用空间分配担保。
什么是空间分配担保就是空间不够了向老年代借用内存。
+是允许担保失败 -是不允许担保失败。
-------------47---空间分配担保------------------------------------------------
堆不是对象分配的唯一选择了。
栈上分配:
方法执行要用到栈帧,执行完毕栈帧出栈。
逃逸分析就是分析对象的作用域。
对象被定义在方法体的话,访问就只限于方法体。一旦引用外部成员就逃逸。
没有逃逸就分配到栈上去了。
只在方法体有效外部是无法引用得就不逃逸了。
----
例子:
不发生逃逸得对象都是在栈中分配得。在使用得过程中可以创建局部对象就不要放在外面去。
------------------------48---------------逃逸分析与栈上分配--------------------------------------------