jvm学习-3.GC与JVM分代模型
作者:互联网
1.什么是垃圾
一般情况下在出栈时,该方法所引用的实例对象就变成了没有任何地方指向他,变成了一个未被引用的对象
定义:如果某个实例对象没有任何一个方法的局部变量指向他,也没有任何一个类的静态变量,包含常量等地方指向他就称之为堆中的垃圾
2.什么时候触发GC
对于堆中的垃圾是在新建对象的时候,发现堆中内存不足时才会去触发GC
GC的内存区域包含了堆,方法区
在方法区中的类变量没有任何使用的情况下才会被GC
GC应当保持频率越少越好
3.jvm分代模型
分为新生代,老年代,永久代
新生代和老年代存在于堆内存中
永久代存在于方法区(1.8以后为元数据区)
刚创建出来的对象绝大部分都是在新生代
默认会将15次以上的对象放入老年代
另外虚拟机栈是用不到GC的因为在出栈的时候,相应的局部变量等数据都会被直接删掉
4.JVM内存核心参数
堆内存配置
XMS java堆内存大小
XMX java堆内存的最大大小
XMN java堆中新生代的大小
XMS-XMN 就是老年代的大小了
方法区配置
XX:PermSize 永久代大小
XX:MaxPermSize 永久代最大大小
XSS 每个线程的栈内存大小
一般堆内存和堆最大内存是一致的
XMS等于XMX
一般永久代大小也是等于永久代最大大小的
XX:PermSize等于XX:MaxPermSize
配置时
-Xms512M -Xmx512M -Xmn256M -Xss1M (堆和栈配置)
-XX:PermSize=128M -XX:MaxPermSIze=128(永久代配置)
配置模板:
-Xms4096M -Xmx4096M -Xmn3072M -Xss1M -XX:PermSize=256M -XX:MaxPermSize=256M -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:CMSInitiatingOccupancyFaction=92 -XX:+UseCMSCompactAtFullCollection -XX:CMSFullGCsBeforeCompaction=0 -XX:+CMSParallelInitialMarkEnabled -XX:+CMSScavengeBeforeRemark -XX:+DisableExplicitGC-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\test\dump\test.hprof
-XX:+UseParNewGC 指定parnew做为ygc回收器
-XX:+UseConcMarkSweepGC 指定cms做为fullgc回收器
-XX:CMSInitiatingOccupancyFaction 为空间担保百分比 老年代超过92%触发fgc
-XX:+UseCMSCompactAtFullCollection 开启内存碎片整理
-XX:CMSFullGCsBeforeCompaction 多少次full gc之后做一次内存整理 默认是0也就是每一次fullgc之后就做一次内存整理 这个内存整理也是会触发stw停止所有线程一段时间
-XX:+CMSParallelInitialMarkEnabled cms初始标记阶段开启多线程标记默认是开启cpu的核心数
-XX:+CMSScavengeBeforeRemark 在CMS 重新标记阶段前启动一次ygc
-XX:+DisableExplicitGC 禁止显式执行GC避免代码中的System.gc()
-XX:+HeapDumpOnOutOfMemoryError 开启堆内存溢出时的快照
-XX:HeapDumpPath=D:\test\dump\test.hprof 快照存放位置
标签:堆中,永久,XX,分代,GC,内存,jvm,PermSize 来源: https://blog.csdn.net/qq_34124558/article/details/118295419