垃圾收集与内存分配

1.判断对象存活状态

1.引用计数算法(在对象中添加一个计数器):难以解决循环引用的问题;
2.可达性分析算法:通过一系列“GC Roots”的根对象作为起始节点集,从这些节点开始,根据引用关系向下搜索,搜索过程所走过的路径称为“引用链”,如果某个对象到GC Roots间没有任何引用链相连,则证明此对象是不可能在被使用的;
3.finalize方法:如果对象在进行可达性分析后发现没有与GC Roots相连接的引用链,那它将会被第一次标记,随后进行一次筛选,筛选的条件是此对象是否有必要执行finalize()方法,假如对象没有被覆盖finalize()方法,或者finalize方法已经被虚拟机调用过,那么虚拟机将这两种情况都视为“没有必要执行”;

2.垃圾收集算法

1.分代收集

一.部分收集:
1.新生代收集(Minor GC/Young GC):指目标只是新生代的垃圾收集
2.老年代收集(Major GC/Old GC)(目前只有CMS收集器会有单独收集老年代的行为):指目标只是老年代的垃圾收集
3.混合收集:指目标是整个新生代和部分老年代的垃圾收集。目前只有G1收集器会有这种行为
二.整堆收集(Full GC):收集整个Java堆和方法区的垃圾收集
在这里插入图片描述

3.内存分配

1.大多数情况下,对象在新生代Eden区中分配。当Eden区没有足够空间进行分配时,虚拟机将发起一次Minor GC;
2.大对象直接进入老年代;
3.长期存活的对象进入老年代;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值