垃圾收集与内存分配

Posted 背时的哥哥

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了垃圾收集与内存分配相关的知识,希望对你有一定的参考价值。

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.长期存活的对象进入老年代;

以上是关于垃圾收集与内存分配的主要内容,如果未能解决你的问题,请参考以下文章

垃圾收集器与内存分配策略---垃圾收集算法

Java垃圾收集器与内存分配策略

垃圾收集器与内存分配策略之垃圾收集算法

垃圾收集器与内存分配策略

垃圾收集器与内存分配策略之篇一:简要概述和垃圾收集算法

垃圾收集器与内存分配策略