java 垃圾回收机制

一、如何判断一个对象是否存活?

没有被任何对象所引用,两种方式:引用计数算法和可达性分析算法

(1)引用计数算法:

每个对象实例都有一个引用计数器,被引用+1,完成引用-1;存在虚拟机上的,任何引用对象为0 的实例可以被当做垃圾来回收的。

优点:执行效率高,程序执行受影响小。

确定:无法检测出循环引用的情况。

(2)可达性分析算法

判断对象的引用链是否可达,决定对象是否是否被回收

GC根开始遍历,可达的被标记存活。

二、可作为GC Roots的对象有哪些?

虚拟机栈中引用的对象

方法区中常量引用的对象

方法区中类静态属性引用的对象

本地方法中JNI(Native方法)的引用对象

活跃的线程的引用对象

三、垃圾回收算法有哪些?

(1)标记清除算法:从根集合进行扫描,不可达的对象进行清楚。

缺点:碎片化,不连续的内存碎片。后续较大的内存时候,无法分配。

(2)复制算法:

分为对象面和空闲面,对象在对象面上创建,存活的对象被从对象面复制到空闲面,将对象面所有的对象内存清除

优点:解决碎片化问题,顺序分配内存,简单高效

(3)标记整理算法

标记清除算法基础上,进行对象移动。

避免了内存不连续性,不用设置两块内存互换适用于存活率高的场景

(4)分代收集算法

垃圾回收算法的组合拳,按照不同对象生命周期的不同区域进行回收。

四、GC是什么?为什么要GC?

Generational Collector,分代收集算法

垃圾回收算法的组合拳,按照不同对象生命周期的不同区域进行回收。

目的:提供JVM垃圾回收效率

五、Minor GC 和 Full GC的区别?

Minor GC :新生代

年轻代:

Eden区

两个Surcivor区

六、对象如何晋升到老年代?

经历一定的Monor GC次数,依然存活的对象。一般15次

Survivor区中存放不下的对象

新生成的大对象

七、常用的调优参数?

老年代:标记清理算法和标记整理算法

八、Full GC 的触发条件?

(1)老年代空间不足

(2)JDC 7以下,永久代空间不足

(3)Monir GC晋升到老年代的平均大小 大于老年代的剩余空间

(4)程序调用了System.gc();

九、JVM 的运行模式:

Server  和Client模式

十、有哪些垃圾回收器?

十一、强引用、软引用、弱引用、虚引用是什么,有什么区别?

String str=new String(original:"abc");//强引用

SoftReference<String> softRef=new SoftReference<String>(str);//软引用

(1)强引用:

抛出内存溢出终止程序也不会回收具有强引用的对象

通过将对象设置为null来弱化引用,使其被回收。

(2)软引用:

对象处在有用但非必须的状态

只有将内存不足时候,GC会回收

可以用来实现高速缓存

(3)弱引用:

非必须的对象,比软引用更弱一些。GC时会被回收,被回收的概率也不大,因为GC线程优先级比较低,适用于引用偶尔被使用且不影响垃圾收集的对象。

(4)虚引用:

不会决定对象的生命周期,任何时候都可能被垃圾回收器回收。跟踪对象被垃圾收集器回收的活动,起哨兵的作用。必须和引用队列referenceQueue联合使用

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值