java虚拟机-垃圾收集器与内存分配

本文详细探讨了垃圾收集器的工作原理,如Serial、ParNew、ParallelScavenge、SerialOld和CMS,以及G1收集器的特性。讲解了引用计数算法和根搜索算法,引用分类,对象存活判断和回收策略,特别关注了内存分配与回收的规则和常见收集算法如标记-清除、复制和标记-整理。

垃圾回收机制

垃圾收集就是我们熟知的GC(Carbage Collection),为了达到更高的并发量,我们需要对这些自动化技术实施监控与调节

新生代 GC(Minor GC):指发生新生代的的垃圾收集动作,Minor GC 非常频繁,回收速度一般也比较快。

老年代 GC(Major GC/Full GC):指发生在老年代的 GC,出现了 Major GC 经常会伴随至少一次的 Minor GC(并非绝对),Major GC 的速度一般会比 Minor GC 的慢 10 倍以上。

Gc触发时机

https://www.cnblogs.com/williamjie/p/9516367.html

对象已死

堆里几乎存有所有对象实例。垃圾回收对象前,首先需要判断对象是否还存活,这里有两种方法,引用计数算法和根搜索算法(可达性分析)。

推荐对象分配的地方的博客

https://blog.csdn.net/zhaohong_bo/article/details/89419480

引用计数算法

在对象中添加一个引用计数器,每当有一个地方引用它是加一,引用失效则减一。任何时刻引用计数都为零的对象,不可能再被使用。
优点:简单高效
缺点:很难解决循环引用问题
java你要使用这种方式管理内存。

根搜索算法

根搜索算法基本思路:通过一系列名为"GC Roots”的对象为起始点,从这些节点向下搜索,经过路线就是引用链,当一个对象和GC Roots之间没有引用链,即不可达时,证明对象是不可用的。

可作为GC Roots的对象:

  • 栈帧中本地变量表的引用对象
  • 方法区中的类静态属性引用的对象
  • 方法区中的常量引用对象
  • 本地方法栈中JNI(Native方法)引用的对象
  • Thread - 活着的线程

引用的分类

JDK1.2之前,引用就是reference类型的数据中储存着一块内存的起始地址,就是引用。只有是或者不是,非常狭隘。
JDK1.2之后,对引用的概念进行扩充,出现了我们熟悉的四种引用,强引用(Strong Reference),软引用(Soft Reference),弱引用(Weak Reference),虚引用(Phantom),强度依次递减。

  • 强引用:普遍存在的,类似 Object obj = new Object()这类引用,只要强引用还在,垃圾回收器就不可能回收它
  • 软引用:描述一些还有用,但非必须的类。系统将要内存溢出之前,把这些对象列入回收范围进行二次回收。JDK1.2后,提供 SoftReference类实现软引用。
  • 弱引用:描述非必须对象。下一次GC到来时,回收。hanlder的内存泄露的解决,ThreadLoacl的实现中,都有使用。JDK 1.2后,提供了WeakReference实现弱引用
  • 虚引用:最弱的一种引用,不会对一个对象的生存时间产生影响,无法通过虚引用来取得一个对象实例。采用虚引用,唯一目的就是希望对象被回收时取得一个系统通知。JDK1.2后,提供PhantomReference来实现虚引用。

对象存活判断

在可达性分析中,某个对象不可达,不是就立即死亡,而是在缓刑阶段。宣告一个对象死亡,至少要经过两次标记过程:在可达性分析中,对象不可达,会被第一次标记并进行一次筛选,筛选条件是对象是否有必要执行finalize()方法

没有必要执行的两种情况:
(1)对象没有覆盖finalize()方法
(2)finalize()方法已经被虚拟机调用了

如果对象被判定有必要执行finalize()方法,那么它会被放置在一个 名字为 F-Queue的队列中,然后有一条虚拟机自动建立的,低优先级

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值