读《深入理解Java虚拟机》- 笔记02

作者: 阿历Ali | 来源:发表于2018-07-07 18:08 被阅读15次

《深入理解Java虚拟机:JVM高级特性与最佳实践》第2版

13. 内存分配(一般来说,不是绝对的)
大方向在堆上分配(也可能被JIT间接分配到栈),对象主要、优先分配在新生代Eden区,少数情况下也可能直接分配在老年代中;如果启动了本地线程分配缓冲,将按线程优先在TLAB上分配。

TLAB: Thread-local allocation buffer,每个线程都有自己的线程缓冲区。

分配细节取决于使用哪种垃圾收集器组合,以及与虚拟机与内存相关的参数设置。

收集器组合:回收新生代、老年代的收集器不同,可以指定。

14. 当Eden区没有足够的空间时,虚拟机将发起一次Minor GC

15. 大对象(例如很长的字符串、数组)直接进入老年代,避免Eden及两个Survivor发生大量的内存复制。

16. 从Eden到Survivor到老年代的晋升过程
如果对象在Eden出生,并经历一次Minor GC之后依然存活,并且能被Survivor容纳的话,将被移到Survivor,年龄记为1;

在Survivor每熬过一次Minor GC,年龄增加1;

当年龄增加到一定程度(默认为15,通过参数 -XX:MaxTenuringThreshold设置),晋升到老年代中;

如果在Survivor空间中相同年龄所有对象大小总和大于Suivivor空间的一半,年龄大于或等于该年龄的对象直接进入老年代,无需等到MaxTenuringThreshold。

17. 空间分配担保 (简单看看)
在发生Minor GC之前,虚拟机会先检查老年代最大可用的连续空间(T)是否大于新生代所有对象空间(N)。

如果T>N,那么Minor GC是安全的;

如果不成立,则虚拟机查看HandlePromotionFailure设置值是否允许担保失败。

如果允许失败,那么继续检查老年代最大可用连续空间是否大于历次晋升到老年代对象的平均大小;

如果大于,将尝试进行一次Minor GC;

如果小于,或者不允许失败,那么此时要进行Full GC;

如果担保失败了,那就发起一次Full GC。

18. 对于17的更正
在JDK 6 Update 24之后,HandlePromotionFailure参数无效。
只要老年代的连续空间大于新生代对象总大小,或者历次晋升平均大小就会进行Minor GC,否则进行Full GC。

第4章 虚拟机性能监控与故障处理工具

19. 虚拟机性能监控与故障处理工具之jinfo
Configuration Info for Java,实时查看和调整虚拟机各项参数。

jinfo -flag name ... (不确定) 查看参数;
jinfo -flag [+|-] name 或者 -flag name=value修改一部分运行期可写的虚拟机参数值。

20. jmap Java内存映像工具与jhat堆转储快照分析工具
Sun JDK 提供jhat命令与jmap搭配使用,分析jmap生成呃堆转储快照,分析内存泄漏问题。

21. jstack Java堆栈跟踪工具
jstack生成当前时刻线程快照。当线程出现停顿的时候查看各个线程的调用堆栈,看看它在后台做什么事情,或者等待什么资源。

22. 在虚拟机使用解释器执行的时候,“在作用域之内”才能保证System.gc()不会回收。因为这里的回收还涉及局部变量表Slot复用、即使编译器介入时机等问题。(参考第8章)


未完待续...

读《深入理解Java虚拟机》- 笔记01

相关文章

网友评论

    本文标题:读《深入理解Java虚拟机》- 笔记02

    本文链接:https://www.haomeiwen.com/subject/aqzwuftx.html