java8 jvm gc_(JDK1.8)JVM GC整理——堆

一、判断对象是否消亡的算法

1、引用计数算法 —— 因为无法解决对象直接相互引用的问题,因此主流的java虚拟机没有选用此方法

基本思想:为每一个对象添加一个引用计数器,每当有一个地方引用这个对象时,计数器值加1,当引用失效时,计数器值减1;任何时刻计数器的值为0的对象都是可被回收对象。

2、可达性分析法

基本思想:将一系列被称为GC Roots的变量作为初始的存活对象集合,然后从该集合出发,所有能被该集合引用到的对象,将其加入到集合中,不能被该集合引用到的对象,则宣告它们死亡。

GC Roots : 是一些由堆外指向堆内的引用

一般而言GC Roots包括但不限于以下几种:

Java 方法栈桢中的局部变量;

已加载类的静态变量;

JNI handles;

已启动且未停止的 Java 线程

二、堆内存分布

1、新生代:

新生代按照8:1:1的比例分为Eden(伊甸区)和两个幸存区Survivor(from和to)

2、老年代

三、GC算法

1、标记清除:

标记清除是最早开发出来的算法。从根开始将可能被引用的对象用递归的方式进行标记,然后将没有被标记的对象作为垃圾进行回收

2、标记整理:

标记整理又称为标记压缩,是标记清除的变种。因为标记清除会造成很多内存碎片,标记整理就是将标记清除后的内存进行碎片整理

3、复制收集

将可用内存按容量划分为大小相等的两块区域,每次只使用其中一块,当这一

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值