我是靠谱客的博主 简单朋友,最近开发中收集的这篇文章主要介绍java gc日志解析_java gc日志详解,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

a3a6211aee8adf0fdb350040ad4de7c9.png

ff5c4f109f1f2949850ec9f3721fe2e9.png

从 Full GC 信息可知,新生代可用的内存大小约为 18M,则新生代实际分配得到的内存空间约为 20M(为什么是 20M? 请继续看下面...)。老年代分得的内存大小约为 42M,堆的可用内存的大小约为 60M。可以计算出: 18432K ( 新生代可用空间 ) + 42112K ( 老年代空间 ) = 60544K ( 堆的可用空间 )

新生代约占堆大小的 1/3,老年代约占堆大小的 2/3。

java执行时jvm参数设定:-Xms60m 3 -Xmx60m 4 -Xmn20m 5 -XX:NewRatio=2。

按上面代码中注释的信息设定 jvm 相关的参数项,并执行程序,下面是一次执行完成控制台

[ GC [ PSYoungGen: 1351K -> 288K (18432K) ] 1351K -> 288K (59392K)

从因为 jvm 每次只是用新生代中的 eden 和 一个 survivor,因此新生代实际的可用内存空间大小为所指定的 90%。

因此可以知道,这里新生代的内存空间指的是新生代可用的总的内存空间,而不是指整个新生代的空间大小。

最后,这里还指定了 PermSize = 30m,PermGen 即永久代 ( 方法区 ),它还有一个名字,叫非堆,主要用来存储由 jvm 加载的类文件信息、常量、静态变量等。

最后

以上就是简单朋友为你收集整理的java gc日志解析_java gc日志详解的全部内容,希望文章能够帮你解决java gc日志解析_java gc日志详解所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(55)

评论列表共有 0 条评论

立即
投稿
返回
顶部