JVM学习心得体会

并发概念:一个人处理多件事。

并行概念:一个事由多个人处理。

jvm:垃圾回收

垃圾回收的过程

1.发现垃圾

2.回收垃圾 

通用的垃圾回收机制

1.引用计数法

2.引用可达法

内存模型

堆内存:包括 栈stack  堆 heap 方法区 method area

垃圾回收分代机制

Eden 区 

年轻代:survivor  1 ,survivor 2

年长代:年轻代里面的数据经过15次循环都没有被清除掉的话,就进入年老代

永久代:jdk1.8以后永久代更换为元空间 metespace

MinorGC:主要用于清理年轻代里面的垃圾,会引发stop the word ,暂停其他用户线程

MajorGC:主要用于清理年老代的垃圾

FullGC:用于清理年轻代和年老代的垃圾,但是成本高,会对系统性能产生影响

SystemGC:用于程序员手动的清理垃圾,只是建议系统来清理垃圾,但是具体起到垃圾回收的作用没有,还不一定,具体会不会对系统执行还是要看系统是否要调用。

对象首先分配到Eden区里面,当新生代空间不住时,触发minorGC,Eden区和from存活的对象使用copy复制to中,存活的对象年龄加1,并且交换from to。

minorGC 会引发stop the word ,暂停其他用户的线程,等垃圾回收结束后,用户线程才能恢复运行,当对象寿命超过阈值时,就会晋升到老年代,最大寿命是15次。

当老年代空间不足时,会先尝试触发minorGC,如果之后空间不足,那么触发fullGC,SWT时间更长

垃圾回收器:

1.串行:(-XX:+UseSerialGC=Serial+serialOld)

单线程:堆内存较小,适合个人电脑

2.吞吐量优先(-XX:+UseParallelGC)

多线程,堆内存较大,多核CPU

3.响应时间优先(-XX:+UseConcMarkSweepGC)(-XX:+UseParNewGC~SerialOld)

多线程,堆内存较大,多核CPU,在程序运行的期间,尽可能让stw的时间最短。

G1垃圾回收  Garbage First

适用场景:同时注重吞吐量和低延迟,默认暂停的目标是200ms

超大的堆内存,会将堆划分为多个相等的region

整体上是标记+整理算法,两个区域之间是复制算法。

-XX:+UseG1GC

-XX:G1HeapRegionSize=size

-XX:MaxGCPauseMillis=time

Mixed  Collection  -XXMaxGCPauseMullis=ms

会对ESO进行全面的垃圾回收

最终标记法:remark 会STW

拷贝存活:evacuation 会STW

FullGC

SerialGC:新生代内存不足时的垃圾回收等  -minorGC

                   老年代内存不足时的垃圾回收等 -fullGC

ParallelGC:新生代内存不足时的垃圾回收等  -minorGC

                   老年代内存不足时的垃圾回收等 -fullGC

CMS:新生代内存不足时的垃圾回收等  -minorGC

                   老年代内存不足时的垃圾回收等 -fullGC

G1:新生代内存不足时的垃圾回收等  -minorGC

                   老年代内存不足时  触发  并发标记/混合收集

Young Collection 新生代

                             跨带引用

Remark 

        Pre  -write barrier +stab -mark -quene  写屏障

JDK 8u20字符串去重

优点:节省大量的空间内存

缺点:略微多占用CPU时间,新生代回收的时间略微增加。

-XX&#x

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值