ThreadLocal前奏:我理解的java四种引用类型

简介: ThreadLocal前奏:我理解的java四种引用类型

前言


为了理解ThreadLocal,掌握引用的概念是非常有必要的。


引用与对象


java中我们通过一个引用指向内存中对象。

//创建一个引用,引用可以独立存在,并不一定需要与一个对象关联
User user;
user =  new User();

user是引用, 通过‘=’指向了内存中的对象。


四种引用


JDK1.2后,根据对对象的引用强度不同,将引用分为4种类型。


强引用:

平时使用最多,最普遍的引用。

User user;
user =  new User();//强引用
  • user就是强引用
  • 堆中的User对象实例,就是“被应用”;

只要user 指向 User对象。User对象就不会被回收。

user = null;断开了引用,User对象不可达,会被回收。


软引用:

我们可以通过SoftReference来定义一个软引用

SoftReference<User> softRef=new SoftReference<User>(new User());//软引用
  • 如果一个对象只有软引用,内存足够时,GC时不回收他。如果内容空间不足时,就会回收被软引用指向的对象内存。
  • 只要没有别回收,还可以使用

解释下:对象只有软引用对象有两种引用的情况

User user  = new User();//强引用
SoftReference<User> softRef=new SoftReference<User>(user);//软引用

对象只有软引用情况

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

User user  = new User();//强引用
SoftReference<User> softRef=new SoftReference<User>(user);//软引用
user = null;//断开了强引用。 此时只有软引用。

软引用可与引用队列(ReferenceQueue)联合使用,在创建软引用时,关联ReferenceQueue。如果软引用引用的对象被回收时,Java虚拟机会把这个软引用加入到与之关联的引用队列中。

软引用可用作内存敏感的高速缓存。


弱引用:

可以通过WeakReference来定义一个弱引用

WeakReference<> weak = new WeakReference<>(new User());//定义一个软引用指向堆内User对象
  • 如果对象只有弱引用,GC时,不管内存是否足够。都会回收,弱引用指向的对象。

弱引用也可与引用队列(ReferenceQueue)联合使用,在创建弱引用时,关联ReferenceQueue。如果弱引用引用的对象被回收时,Java虚拟机会把这个弱引用加入到与之关联的引用队列中。

ThreadLocal 中使用到了弱引用。


虚引用:

虚引用是最弱的引用,弱到,不能用弱引用访问到对象。

可以通过PhantomReference来定义一个虚引用。

虚引用,主要用来跟踪对象被垃圾回收器回收的活动。

虚引用必须与引用队列(ReferenceQueue)一起使用,当垃圾回收器准备回收一个对象时,如果发现它还有虚引用,就会在回收对象的内存之前,把这个虚引用加入到与之 关联的引用队列中。我们可以根据引用是否在队列中,来判断对象的回收活动。


为什么需要不同的引用类型

我们看出引用强度的不同,对象的生命周期不同,垃圾回收策略丰富,有利于更好的管理对象内存。


总结:


  • 引用与对象的生命周期相关。
  • 对象可以被多种类型的,多个引用指向,但只要有一个强引用。垃圾回收器不回收。

关键时理解: 一个对象,可以被多种类型引用同时指向,强度最高的决定他的生命周期

注意:这里的内存应该是指“堆内存”,并且区分引用类型基本类型

//String user ="user";//
String user = new String("user");
SoftReference<String> softRef=new SoftReference<String>(user);
WeakReference<String> weak = new WeakReference<String>(user);
user=null;
System.out.println(softRef.get());
System.gc();
System.out.println(weak.get());



相关文章
|
5月前
|
缓存 算法 Java
Java面试题:深入探究Java内存模型与垃圾回收机制,Java中的引用类型在内存管理和垃圾回收中的作用,Java中的finalize方法及其在垃圾回收中的作用,哪种策略能够提高垃圾回收的效率
Java面试题:深入探究Java内存模型与垃圾回收机制,Java中的引用类型在内存管理和垃圾回收中的作用,Java中的finalize方法及其在垃圾回收中的作用,哪种策略能够提高垃圾回收的效率
41 1
|
2月前
|
存储 Java 程序员
【一步一步了解Java系列】:何为数组,何为引用类型
【一步一步了解Java系列】:何为数组,何为引用类型
28 1
|
2月前
|
存储 Java 编译器
[Java]基本数据类型与引用类型赋值的底层分析
本文详细分析了Java中不同类型引用的存储方式,包括int、Integer、int[]、Integer[]等,并探讨了byte与其他类型间的转换及String的相关特性。文章通过多个示例解释了引用和对象的存储位置,以及字符串常量池的使用。此外,还对比了String和StringBuilder的性能差异,帮助读者深入理解Java内存管理机制。
21 0
|
3月前
|
算法 安全 Java
JAVA并发编程系列(12)ThreadLocal就是这么简单|建议收藏
很多人都以为TreadLocal很难很深奥,尤其被问到ThreadLocal数据结构、以及如何发生的内存泄漏问题,候选人容易谈虎色变。 日常大家用这个的很少,甚至很多近10年资深研发人员,都没有用过ThreadLocal。本文由浅入深、并且才有通俗易懂方式全面分析ThreadLocal的应用场景、数据结构、内存泄漏问题。降低大家学习啃骨头的心理压力,希望可以帮助大家彻底掌握并应用这个核心技术到工作当中。
|
4月前
|
存储 安全 Java
Java 中的 ThreadLocal 变量
【8月更文挑战第22天】
39 4
|
5月前
|
存储 SQL Java
(七)全面剖析Java并发编程之线程变量副本ThreadLocal原理分析
在之前的文章:彻底理解Java并发编程之Synchronized关键字实现原理剖析中我们曾初次谈到线程安全问题引发的"三要素":多线程、共享资源/临界资源、非原子性操作,简而言之:在同一时刻,多条线程同时对临界资源进行非原子性操作则有可能产生线程安全问题。
|
6月前
|
缓存 Java 开发者
深入理解Java的五种引用类型
深入理解Java的五种引用类型
|
6月前
|
存储 安全 Java
深入理解Java中的ThreadLocal机制:原理、方法与使用场景解析
深入理解Java中的ThreadLocal机制:原理、方法与使用场景解析
93 2
|
5月前
|
存储 缓存 Java
Java面试题:解释Java中的内存屏障的作用,解释Java中的线程局部变量(ThreadLocal)的作用和使用场景,解释Java中的锁优化,并讨论乐观锁和悲观锁的区别
Java面试题:解释Java中的内存屏障的作用,解释Java中的线程局部变量(ThreadLocal)的作用和使用场景,解释Java中的锁优化,并讨论乐观锁和悲观锁的区别
54 0
|
5月前
|
并行计算 算法 安全
Java面试题:解释Java内存模型的内存屏障,并讨论其对多线程并发的影响,解释Java中的线程局部变量(ThreadLocal)的工作原理,解释Java中的ForkJoinPool的工作原理
Java面试题:解释Java内存模型的内存屏障,并讨论其对多线程并发的影响,解释Java中的线程局部变量(ThreadLocal)的工作原理,解释Java中的ForkJoinPool的工作原理
42 0