[toc]
内存回收机制
当一个对象不再被引用的时候,内存回收它占领的空间,以便空间被后来的新对象使用。我们都知道将一个对象设置为null之后,那么这个对象就不再被引用了,最终JVM就会回收它。
强引用
强引用(
StrongReference
):默认引用,如果一个对象具有强引用,垃圾回收器绝不会回收它。在内存空间不足时,Java虚拟机宁愿跑出了 OutOfMemory 的错误,使程序异常终止,也不会强引用的对象来解决内存不足问题。
例如:
//强引用
Object obj = new Object()
//解除强引用
obj = null
软引用
软引用(
SiftReference
):描述一些还有用但非必需的对象,用java.lang.ref.SoftReference类表示,如果内存空间足够,垃圾回收器就不会回收它,也就是说在JVM抛出OutOfMemoryError之前,会去清理软引用对象。软引用可以与引用队列(ReferenceQueue)联合使用。
例如:
Object obj = new Object();
//从强引用中获取软引用
SoftReference<Object> softReference = new SoftReference<>(obj);
//去除强引用
obj = null;
// get方法返回此引用对象的指示对象。用来获取与软引用关联的对象的引用
Object softObj = softReference.get();
弱引用
弱引用(
WeakPeference
):垃圾回收器一旦发现了只具有弱引用的对象,不管当前内存空间足够与否,都会回收它的内存 .通过WeakReference类实现的,它的生命周期比软引用还要短,也是通过get()方法获取对象
例如:
Object obj = new Object();
//从强引用中获取软引用
WeakReference<Object> weakReference = new WeakReference<>(obj);
//去除强引用
obj = null;
// get方法返回此引用对象的指示对象。用来获取与软引用关联的对象的引用
Object weakObj = weakReference.get();
虚引用
虚引用也称幻想引用(PhantomReference):如果一份对象仅持有虚引用,那么它就和没有任何引用一样,无法通过虚引用访问对象的任何属性或者函数,在任何时候都可能被垃圾回收器回收,虚引用是必须配合ReferenceQueue 使用的,主要用来跟踪对象被垃圾回收的活动。
例如:
Object obj = new Object();
ReferenceQueue referenceQueue = new ReferenceQueue();
PhantomReference<Object> phantomReference = new PhantomReference<Object>(obj, referenceQueue);
obj = null;
Object phantObj = phantomReference.get();