Java中对象的几种引用
2013-11-14 22:34
225 查看
在Java中对象的引用有如下四种:
1、强引用(StrongReference)
这是Java最常见的引用方式,创建一个对象,并把它赋给一个引用变量,程序通过该变量来操作实际的对象,当一个对象被其他引用变量引用时,它处于激活状态,就不可能被垃圾回收。
2、软引用(SoftReference)
需要通过SoftReference类来实现,当一个对象只具有软引用时,它有可能被回收,即当内存足够时,它不会被回收;内存不足时,系统将会回收它。所以软引用通常用于对内存敏感的程序中。
3、弱引用(WeekReference)
需要通过WeekReference类来实现,它和软引用很像,但比软引用级别更低。对于只有弱引用的对象而言,当系统垃圾回收机制运行时,不管内存是否足够,该对象所占的内存总会被回收,但并不是说就立即回收。
4、虚引用(PhantomReference)
需要通过PhantomReference实现,虚引用完全类似没有引用,主要用于跟踪对象被垃圾回收的状态,它不能单独使用,必须和引用队列(ReferenceQueue)联合使用。
上面三个类都有一个get方法用于获取它们所引用的对象。
下面示例示范了弱引用所引用对象也会被垃圾回收过程:
下面示例示范了虚引用和引用队列的结合使用:
使用这些类可以避免在程序运行期间将对象留在内存中,这样垃圾收集器就可以随意地释放对象,可以尽可能减少程序在生命周期中所占用的内存大小。
本文知识点和示例原型来源疯狂JAVA讲义一书
1、强引用(StrongReference)
这是Java最常见的引用方式,创建一个对象,并把它赋给一个引用变量,程序通过该变量来操作实际的对象,当一个对象被其他引用变量引用时,它处于激活状态,就不可能被垃圾回收。
2、软引用(SoftReference)
需要通过SoftReference类来实现,当一个对象只具有软引用时,它有可能被回收,即当内存足够时,它不会被回收;内存不足时,系统将会回收它。所以软引用通常用于对内存敏感的程序中。
3、弱引用(WeekReference)
需要通过WeekReference类来实现,它和软引用很像,但比软引用级别更低。对于只有弱引用的对象而言,当系统垃圾回收机制运行时,不管内存是否足够,该对象所占的内存总会被回收,但并不是说就立即回收。
4、虚引用(PhantomReference)
需要通过PhantomReference实现,虚引用完全类似没有引用,主要用于跟踪对象被垃圾回收的状态,它不能单独使用,必须和引用队列(ReferenceQueue)联合使用。
上面三个类都有一个get方法用于获取它们所引用的对象。
下面示例示范了弱引用所引用对象也会被垃圾回收过程:
package com.home.reference; import java.lang.ref.WeakReference; public class TestWeekReference { public static void main(String[] args) { String str = new String("测试弱引用"); // 创建一个弱引用,让此引用指向"测试弱引用"字符串 WeakReference wr = new WeakReference(str); str = null;// 切断str和"测试弱引用"字符串之间的引用 System.out.println(wr.get());// 取出弱引用所引用的对象 System.gc(); System.runFinalization(); System.out.println(wr.get());// 再次取出弱引用所引用的对象 } }
下面示例示范了虚引用和引用队列的结合使用:
package com.home.reference; import java.lang.ref.PhantomReference; import java.lang.ref.ReferenceQueue; public class TestPhantomReference { public static void main(String[] args) { String str = new String("测试虚引用"); ReferenceQueue rq = new ReferenceQueue();// 创建一个引用队列 // 创建一个虚引用,让该引用指向"测试虚引用"字符串 PhantomReference pr = new PhantomReference(str, rq); // 切断str和"测试虚引用"字符串之间的引用 str = null; // 不能通过虚引用访问被引用的对象,所以输出为null System.out.println(pr.get()); // 强制垃圾回收 System.gc(); System.runFinalization(); // 取出引用队列中最先进入队列的引用与pr进行比较 System.out.println(rq.poll() == pr); } }
使用这些类可以避免在程序运行期间将对象留在内存中,这样垃圾收集器就可以随意地释放对象,可以尽可能减少程序在生命周期中所占用的内存大小。
本文知识点和示例原型来源疯狂JAVA讲义一书
相关文章推荐
- Java内存管理(二)--垃圾回收机制
- java ClassLoader内部原理
- weblogic配置修改java代码后不需要重启热部署方式
- Struts2学习笔记03----Struts2中的VO、ModelDriven机制及其运用
- weblogic配置修改java代码后不需要重启热部署方式
- weblogic配置修改java代码后不需要重启热部署方式
- weblogic配置修改java代码后不需要重启热部署方式
- 我的Java 我做主
- java代码JFrame练习
- Java Map 集合类简介
- java事件监听总结
- Java命名规范
- Java命名规范
- NIO - FileChannel
- NIO - Scatter/Gather
- java焦点的获取和转移
- Java反射那点事(一)
- java学习笔记-File类的基本使用
- 搭建Java版WebService
- Spring+SpringMVC+Hibernate整合+入门笔记