Java四种引用类型

Java从1.2版本开始引入了4种引用,这四种引用的级别由高到低依次为:强引用>软引用>弱引用>虚引用。

一、强引用(StrongReference):

强引用是使用最普遍的引用,一般我们将对象初始化之后就是一个强引用。当一个对象具有强引用时,JVM不会对它进行垃圾回收。当内存不足时,宁愿抛出OutofMemoryError,让程序异常终止,也不会回收强引用。

二、软引用(SoftReference):

如果一个对象是弱引用,如果内存足够就不会对它进行垃圾回收;如果内存空间不足了,就会回收这部分对象。只要垃圾回收器没有对它进行回收,那么程序就可以使用它。软引用可用来实现内存敏感的高速缓存。软引用可以和一个引用队列(ReferenceQueue)联合使用,如果软引用所引用的对象被垃圾回收器回收,Java虚拟机就会把这个软引用加入到与之关联的引用队列中。

三、弱引用(WeakReference):

弱引用和软引用的区别在于弱引用拥有更短的生命周期。当垃圾回收器扫描内存区域时,只要发现弱引用就会对它进行回收。但由于垃圾回收器是一个优先级比较低的线程,因此不一定很快就会发现那些弱引用对象。弱引用可以和一个引用队列(ReferenceQueue)联合使用,如果弱引用所引用的对象被垃圾回收,Java虚拟机就会把这个弱引用加入到与之关联的引用队列中。

四、虚引用(PhantomReference):

与其他几种引用都不同,虚引用并不会决定对象的生命周期。如果一个对象仅持有虚引用,那么它就和没有任何引用一样,在任何时候都可能被垃圾回收器回收。 虚引用主要用来跟踪对象被垃圾回收器回收的活动。虚引用与软引用和弱引用的一个区别在于:虚引用必须和引用队列 (ReferenceQueue)联合使用。当垃圾回收器准备回收一个对象时,如果发现它还有虚引用,就会在回收对象的内存之前,把这个虚引用加入到与之
关联的引用队列中。

示例代码:

强引用:

public class MyClass
{
    MyClass()
    {

    }
}
public class Test
{
    public static void main(String [] args)
    {
        MyClass myClass=new MyClass();
        System.gc();
    }
}

显式的调用了垃圾回收,但由于myClass是强引用,myClass没有被回收。

软引用:

public class MyClass
{
    MyClass()
    {

    }
}
public class Test
{
    public static void main(String [] args)
    {
        MyClass myClass=new MyClass();
        SoftReference ref=new SoftReference(myClass);
        System.gc();
    }
}

内存不足时软引用被回收。

弱引用:

public class MyClass
{
    MyClass()
    {

    }
}
public class Test
{
    public static void main(String [] args)
    {
        MyClass myClass=new MyClass();
        WeakReference ref=new WeakReference(myClass);
        System.gc();
    }
}

在JVM垃圾回收时,弱引用就会被回收。

虚引用:

public class MyClass
{
    MyClass()
    {

    }
}
public class Test
{
    public static void main(String [] args)
    {
        MyClass myClass=new MyClass();
        ReferenceQueue rq=new ReferenceQueue();
        PhantomReference pr=new PhantomReference(myClass,rq);
        System.gc();
    }
}

虚引用,被实例化之后就会被回收。

总结:


级别


什么时候被垃圾回收


用途


生存时间


强引用


从来不会


对象的一般状态


JVM停止运行时终止


软引用


在内存不足时


对象简单?缓存


内存不足时终止


弱引用


在垃圾回收时


对象缓存


gc运行后终止


虚引用


Unknown


Unknown


Unknown

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-12-28 02:16:34

Java四种引用类型的相关文章

你知道Java的四种引用类型吗

从大一自学Java已经两年了,自觉已经可以独当一面,(其实远远不足),最近一直在看书.关于java四种引用类型,我也是刚了解,特此记下! 在Java中提供了四个级别的引用:强引用,软引用,弱引用和虚引用.在这四个引用类型中,只有强引用FinalReference类是包内可见,其他三种引用类型均为public,可以在应用程序中直接使用.引用类型的类结构如图所示. 1.强引用 Java中的引用,类似C语言中最难的指针.(我是C语言入门编程,指针的概念还是很深入我心.)通过引用,可以对堆中的对象进行操

Java的四种引用类型史上最详细,再也不怕面试官

Java四种引用类型 1.引用的基本概念 强引用:当我们使用new创建对象时,被创建的对象就是强引用,如Object object = new Object(),其中的object就是一个强引用了.如果一个对象具有强引用,JVM就不会去GC它,JVM宁可会报OOM来终止程序,也不回收该对象. 软引用: 如果一个对象只具备软引用,如果内存空间足够,那么JVM就不会GC它,如果内存空间不足了,就会GC该对象. 弱引用: 如果一个对象只具有弱引用,只要JVM的GC线程检测到了,就会立即回收.弱引用的生

Java的四种引用类型

Java中有四种引用类型:强引用.软引用.弱引用.虚引用.--应该是从1.2版本开始添加的. 这个概念是与垃圾回收有关的. 如果你不知道这几个概念,那你用的肯定都是强引用.例如String str = new String(); 这个str到 new String() 的引用类型就是强引用. 那什么是弱引用呢?先看一段代码: 1 package cn.larry.pojo; 2 3 public final class Product { 4 private String name; 5 6 p

Java魔法堂:四种引用类型、ReferenceQueue和WeakHashMap

一.前言 JDK1.2以前只提供一种引用类型——强引用 Object obj = new Object(); .而JDK1.2后我们多另外的三个选择分别是软引用 java.lang.ref.SoftReference .弱引用 java.lang.ref.WeakReference 和虚引用 java.lang.ref.PhantomReference .下面将记录对它们和相关连的引用队列 java.lang.ref.ReferenceQueue 和 java.util.WeakHashMap 

java中四种引用类型

java中四种引用类型  今天看代码,里面有一个类java.lang.ref.SoftReference把小弟弄神了,试想一下,接触java已经有3年了哇,连lang包下面的类都不了解,怎么混.后来在网上查资料,感觉收获颇多,现记录如下. 对象的强.软.弱和虚引用 在JDK 1.2以前的版本中,若一个对象不被任何变量引用,那么程序就无法再使用这个对象.也就是说,只有对象处于可触及(reachable)状态,程序才能使用它.从JDK 1.2版本开始,把对象的引用分为4种级别,从而使程序能更加灵活地

Java中的四种引用类型比较

1.引用的概念 引用这个概念是与JAVA虚拟机的垃圾回收有关的,不同的引用类型对应不同的垃圾回收策略或时机. 垃圾收集可能是大家感到难于理解的较难的概念之一,因为它并不能总是毫无遗漏地解决Java运行时环境中堆管理的问题. 垃圾回收的大致思路是:当Java虚拟机觉得内存不够用的时候,会触发垃圾回收操作(GC),清除无用的对象,释放内存.可是如何判断一个对象是否是垃圾呢?其中的一个方法是计算指向该对象的引用数量,如果引用数量为0,那么该对象就为垃圾(Thread对象是例外),否则还有用处,不能被回

java四种引用及在LeakCanery中应用

java 四种引用 Java4种引用的级别由高到低依次为: StrongReference > SoftReference > WeakReference > PhantomReference 1. StrongReference String tag = new String("T"); 此处的 tag 引用就称之为强引用.而强引用有以下特征: 1. 强引用可以直接访问目标对象. 2. 强引用所指向的对象在任何时候都不会被系统回收. 3. 强引用可能导致内存泄漏.

Java四种线程池newCachedThreadPool,newFixedThreadPool,newScheduledThreadPool,newSingleThreadExecutor

介绍new Thread的弊端及Java四种线程池的使用,对Android同样适用.本文是基础篇,后面会分享下线程池一些高级功能. 1.new Thread的弊端 执行一个异步任务你还只是如下new Thread吗? Java new Thread(new Runnable() { @Override public void run() { // TODO Auto-generated method stub } }).start(); 1 2 3 4 5 6 7 new Thread(new

Java四种线程池

Java四种线程池newCachedThreadPool,newFixedThreadPool,newScheduledThreadPool,newSingleThreadExecutor 时间:2015-10-20 22:37:40      阅读:8762      评论:0      收藏:0      [点我收藏+] 介绍new Thread的弊端及Java四种线程池的使用,对Android同样适用.本文是基础篇,后面会分享下线程池一些高级功能. 1.new Thread的弊端执行一个异