- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
JVM 内存分配策略
我们将介绍几个 JVM 中对象在分配内存是应该遵循的策略。毕竟,想要去
优化程序,不仅要考虑垃圾回收的过程,还要从对象内存分配的角度减少 gc 的
代价。
一、gc 日志格式
在这里先介绍一下gc 日志的格式,分析gc 日志是了解gc 过程最直接的
方式。对于大量的日志分析,直接查看日志文件当然不方便,我们一般会使用日
志分析工具,后边会有介绍,但是对于简短的日志(如十几条),一般直接查看
就行了。开启日志输出的JVM 参数如下:
-XX:+PrintGCDetails //打印gc 日志
-XX:+PrintGCDateStamps //打印时间
-Xloggc:gc.log //输出路径
对应的日志输出格式如下(采用不同参数或不同虚拟机可能不同,但大同
小异):
2014-03-09T18:10:47.639+0800: 36.408: [GC 36.408: [DefNew:
35072K-4352K(39424K), 0.0108988 secs] 75088K-45293K(126848K), 0.0109419
secs] [Times: user=0.01 sys=0.00, real=0.01 secs]
2014-03-09T18:10:48.562+0800: 37.331: [Full GC 37.343: [Tenured:
40941K-42890K(87424K), 0.1340821 secs] 62210K-42890K(126848K), [Perm :
36863K-36863K(36864K)], 0.1341736 secs] [Times: user=0.13 sys=0.00, real=0.15
secs]
35072K-4352K(39424K):gc 前使用内存大小-gc 后使用大小(该区域总大小)
2014-03-09T18:10:47.639+0800: gc 时间
36.408: gc 耗时
GC 36.408: 表示停顿类型和停顿时间,如果是 Full 表示gc 是Stop-The-World
的
DefNew: Tenured: Perm : gc 发生的区域,DefNew 年轻代;Tenured 年老代;
Perm 永久代
Times: user=0.13 sys=0.00, real=0.15 secs user :用户态耗时;sys:内核态耗时;
real:gc 从开始到结束消耗的Wall Clock Time 耗时(墙钟时间,名字好怪,包括
各种非运算的等待耗时和cpu 耗时)
二、内存分配策略
1、对象优先在Eden 分配
新的对象大多数情况下在Eden 去分配,这样在Eden 区域没有足够空间
时,JVM 会首先进行Minor Gc,仅对Eden 进行gc,并将符合条件的对象移至年
老代。这样如果Eden 在gc 后满足新对象的空间需求,则能避免进行Full GC。
2、大对象直接进入年老代
这一点十分好理解,多数情况下大对象的生命周期是相对较长的,而大
对象如果分配在 Eden,不仅占用大量空间,触发gc,还可能会在Eden 区/两个
Survivor 区之间来回复制,十分耗费资源。因此,多数时候对于大对象,应该直
接分配至年老代,开始用 -XX:PertenureSizeThreshold 参数指定直接分配年老代的
大小。
3、长期存活的对象进入年老代
一般经过多次Minor GC 而不死的对象,继续活下去的可能新更大,因此
应该进入年老代。为了判断哪些对象长期存活,虚拟机给每个对象都定义了一个
Age 计数器,没经历一次 Minor GC 就+1 ,可以通过-XX:MaxTenuringThreshold 的
值来决定age 达到多少时进入年老代。
4 、动态对象年龄判断
为了能更好地适应不同程序的内存状况,虚拟机并不总是要求对象的年龄
必须达到 MaxTenuringThreshold 才能晋升老年代,如果在 Survivor 空间中相同
年龄所有对象大小的总和大于Surviv
您可能关注的文档
最近下载
- 【事业单位考试真题】2022年江西省交通投资集团有限责任公司校园招考聘用冲刺题(附答案解析).docx VIP
- 环境与可持续发展(北京师范大学)中国大学MOOC(慕课)章节测验试题(答案).pdf
- 倪海厦伤寒论经方使用说明书.docx VIP
- 2025至2030中国商业秤行业市场占有率及投资前景评估规划报告.docx VIP
- 倪海厦《伤寒论》经方使用说明书(打印版).pdf VIP
- 农业产业园项目农产品质量安全监管体系建设与评估报告.docx VIP
- MD110参数设置说明.doc VIP
- 2024年中国私募股权发展蓝皮书.pdf VIP
- 双相障碍治疗建议( 特殊类型)-中国双相障碍防治指南.pdf VIP
- 提高钢结构焊缝一次施工质量合格率(优秀QC成果).docx VIP
原创力文档


文档评论(0)