濮阳网站建设公司,农村自建房设计图纸,wordpress 多商户,做彩票网站能挣到钱吗Java四种引用类型在java中#xff0c;类型就分为两种#xff0c;基本类型和引用类型或自定义类型。引用类型又分为四种#xff1a;强引用 StrongReference软引用 SoftReference若引用 WeakReference虚引用 PhantomReference划分这些类型的目的是#xff1a;是为了更灵活的管…Java四种引用类型在java中类型就分为两种基本类型和引用类型或自定义类型。引用类型又分为四种强引用 StrongReference软引用 SoftReference若引用 WeakReference虚引用 PhantomReference划分这些类型的目的是是为了更灵活的管理对象的生命周期让垃圾器在最合适的时间适合回收对象常见使用的场景是在缓存的实现比如elasticsearch在载入数据到缓存时可以选择SoftReference作为缓存的生命周期在对象池组件common-pool中也利用到SoftReference管理对象池的对象生命周期。虽然我们在实际业务中很少有用到这些知识但是很有必要了解到这些去帮助我们去做些程序性能优化。强引用强引用就是直接引用对象比如下面这样我们在编写程序时用到的大多都是强引用StringBuffer b1 new StringBuffer(hello world);强引用对象当垃圾回收进行时不会被回收及时通过b1 null;释放引用在资源充足时也不会被垃圾回收立刻回收。如果内存吃紧Java虚拟机会抛出OutOfMemoryError错误使程序异常终止不会靠随意回收具有强引用的对象来解决内存不足的问题。软引用SoftReference softReference new SoftReference(new StringBuffer(hello world));System.gc();System.out.print(softReference.get()); // 只有当内存吃紧时发生gc后会报Exception in thread main java.lang.NullPointerException软引用的生命周期会比强引用弱点在内存空间足够时垃圾回收器就不会回收它如果内存空间不足了就会回收这些对象的内存。只要垃圾回收器没有回收它该对象就可以被程序使用。软引用可用来实现内存敏感的高速缓存。它也经常和ReferenceQueue配合使用如果gc在回收掉引用对象后会把保存引用对象的softReference送入队列这时可以通过下面这行代码判断是否被回收。// 创建softReference并提供给注册队列ReferenceQueue referenceQueue new ReferenceQueue();SoftReference softReference new SoftReference(new StringBuffer(hello world),referenceQueue);// 判断入队列来判断是否被回收或直接判断softReference.get() nullsoftReference.get() null || softReference.enqueue()另外也可以手动清除这些保存引用对象的reference对象Reference ref;while ((ref referenceQueue.poll()) ! null) {// poll出即清除也不必手动清除等待gc清除}使用案列common-pool2的SoftReferenceObjectPool用于实现一种可以随着需要而增长的池对象管理当gc时可以清除空闲的实例。下面是common-pool2的部分代码具体可以参照其里面的SoftReferenceObjectPool类Overridepublic synchronized void addObject() throws Exception {assertOpen();if (factory null) {throw new IllegalStateException(Cannot add objects without a factory.);}T obj factory.makeObject().getObject();createCount;// Create and register with the queuePooledSoftReference ref new PooledSoftReference(new SoftReference(obj, refQueue));allReferences.add(ref);boolean success true;if (!factory.validateObject(ref)) {success false;} else {factory.passivateObject(ref);}boolean shouldDestroy !success;if (success) {idleReferences.add(ref);notifyAll(); // numActive has changed}if (shouldDestroy) {try {destroy(ref);} catch (Exception e) {// ignored}}Overridepublic synchronized void returnObject(T obj) throws Exception {boolean success !isClosed();final PooledSoftReference ref findReference(obj);if (ref null) {throw new IllegalStateException(Returned object not currently part of this pool);}if (factory ! null) {if (!factory.validateObject(ref)) {success false;} else {try {factory.passivateObject(ref);} catch (Exception e) {success false;}}}boolean shouldDestroy !success;numActive--;if (success) {// Deallocate and add to the idle instance poolref.deallocate();idleReferences.add(ref);}notifyAll(); // numActive has changedif (shouldDestroy factory ! null) {try {destroy(ref);} catch (Exception e) {// ignored}}}弱引用WeakReference weakReference new WeakReference(new StringBuffer(hello world));WeakReference weakReference2 new WeakReference(new StringBuffer(hello world));System.out.print(weakReference.get()); // hello worldStringBuffer buffer weakReference2.get();System.gc();System.out.print(weakReference.get()); // Exception in thread main java.lang.NullPointerExceptionSystem.out.print(weakReference2.get()); // hello world弱引用会在发生gc时没有对象在去引用时会被立刻被回收不管内存是否充裕。使用案列WeakHashMap虚引用ReferenceQueue stringBufferReferenceQueue new ReferenceQueue();PhantomReference phantomReference new PhantomReference(new StringBuffer(hello world), stringBufferReferenceQueue);System.out.print(phantomReference.get());Exception in thread main java.lang.NullPointerException虚引用不顾是否被垃圾回收都不可以拿到真正的引用对象。一般用法是程序可以通过判断引用队列中是否已经加入了虚引用来了解被引用的对象是否将要被垃圾回收。如果程序发现某个虚引用已经被加入到引用队列那么就可以在所引用的对象的内存被回收之前采取必要的行动。具体Demo代码请参照ReferenceDemo