JUC并发编程-ThreadLocal

2024-09-03 05:28
文章标签 并发 编程 juc threadlocal

本文主要是介绍JUC并发编程-ThreadLocal,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、简介

ThreadLocal 是 Java 中一个重要的工具类,主要用于在多线程环境中提供线程局部变量。这意味着,每个线程都可以拥有自己的变量副本,而不会与其他线程共享这些变量,从而实现线程间的数据隔离。

总结:

  • 线程局部变量:ThreadLocal 中填充的变量属于当前线程,对其他线程而言是隔离的。
  • 副本独立:每个线程都有自己的实例副本,且只能由当前线程使用。
  • 变量隔离:由于每个线程都有独立的实例副本,因此不存在多线程间共享的问题。

2、ThreadLocal 应用场景 

  • 线程间数据隔离,例如数据库连接管理。
  • 线程内数据传递,例如方法间传递参数。

3、ThreadLocal 内存泄露问题

必须回收自定义的ThreadLocal变量,尤其在多线程的场景下,线程会经常被复用,如果不清理自定义的ThreadLocal变量,可能会影响后续业务逻辑和造成内存泄露的问题。

解决方式:

  • 尽量使用try-finally块进行回收

4、ThreadLocal 与 四大引用

强引用(Strong Reference)

  • 定义:最常见的引用类型,如 Object obj = new Object(); 中的 obj 就是一个强引用。
  • 特点:只要强引用存在,垃圾回收器就不会回收被引用的对象,即使内存不足也不会回收。
  • 使用场景:程序中的大多数引用都是强引用。

软引用(Soft Reference)

  • 定义:通过 SoftReference 类实现,如 SoftReference<Object> softRef = new SoftReference<>(new Object());
  • 特点:当内存足够时,软引用对象不会被回收;当内存不足时,垃圾回收器会回收软引用对象。
  • 使用场景:缓存应用,如网页缓存、图片缓存等。

弱引用(Weak Reference)

  • 定义:通过 WeakReference 类实现,如 WeakReference<Object> weakRef = new WeakReference<>(new Object());
  • 特点:弱引用对象更容易被垃圾回收器回收,只要发生垃圾回收,不管内存是否足够,弱引用对象都会被回收。
  • 使用场景:ThreadLocal 的 Key,防止内存泄漏。

虚引用(Phantom Reference)

  • 定义:通过 PhantomReference 类实现,如 PhantomReference<Object> phantomRef = new PhantomReference<>(new Object(), queue);
  • 特点:虚引用对象任何时候都可能被垃圾回收器回收,必须与引用队列(ReferenceQueue)联合使用,回收前会被加入引用队列。
  • 使用场景:用于监控对象的回收,以便在对象被回收时进行一些后续操作。

总结:

只有强引用不会被垃圾回收、软引用只有在内存不足时被垃圾回收、弱引用和虚引用都会被垃圾自动回收

四种引用类型的简单示例:

// 强引用
Object strongRef = new Object();// 软引用
SoftReference<Object> softRef = new SoftReference<>(new Object());// 弱引用
WeakReference<Object> weakRef = new WeakReference<>(new Object());// 虚引用
ReferenceQueue<Object> queue = new ReferenceQueue<>();
PhantomReference<Object> phantomRef = new PhantomReference<>(new Object(), queue);

 

ThreadLocal内部ThreadLocalMap使用弱引用作为Key:

  • 弱引用ThreadLocal 的内部实现 ThreadLocalMap 使用弱引用作为 Key,指向 ThreadLocal 对象。这允许 ThreadLocal 对象在没有其他强引用的情况下被垃圾回收,但不会影响 ThreadLocalMap 中的值。

 

 五、Thread最佳实践

(1)使用 ThreadLocal.withInitial() 方法来初始化 ThreadLocal,这样可以确保每个线程在第一次访问时都有一个默认值。

(2)尽量使用static修饰 ThreadLocal

(3)手动调用remove()

这篇关于JUC并发编程-ThreadLocal的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1132146

相关文章

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

Redis中高并发读写性能的深度解析与优化

《Redis中高并发读写性能的深度解析与优化》Redis作为一款高性能的内存数据库,广泛应用于缓存、消息队列、实时统计等场景,本文将深入探讨Redis的读写并发能力,感兴趣的小伙伴可以了解下... 目录引言一、Redis 并发能力概述1.1 Redis 的读写性能1.2 影响 Redis 并发能力的因素二、

Nginx实现高并发的项目实践

《Nginx实现高并发的项目实践》本文主要介绍了Nginx实现高并发的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录使用最新稳定版本的Nginx合理配置工作进程(workers)配置工作进程连接数(worker_co

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同

PyCharm接入DeepSeek实现AI编程的操作流程

《PyCharm接入DeepSeek实现AI编程的操作流程》DeepSeek是一家专注于人工智能技术研发的公司,致力于开发高性能、低成本的AI模型,接下来,我们把DeepSeek接入到PyCharm中... 目录引言效果演示创建API key在PyCharm中下载Continue插件配置Continue引言

C#反射编程之GetConstructor()方法解读

《C#反射编程之GetConstructor()方法解读》C#中Type类的GetConstructor()方法用于获取指定类型的构造函数,该方法有多个重载版本,可以根据不同的参数获取不同特性的构造函... 目录C# GetConstructor()方法有4个重载以GetConstructor(Type[]

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

高并发环境中保持幂等性

在高并发环境中保持幂等性是一项重要的挑战。幂等性指的是无论操作执行多少次,其效果都是相同的。确保操作的幂等性可以避免重复执行带来的副作用。以下是一些保持幂等性的常用方法: 唯一标识符: 请求唯一标识:在每次请求中引入唯一标识符(如 UUID 或者生成的唯一 ID),在处理请求时,系统可以检查这个标识符是否已经处理过,如果是,则忽略重复请求。幂等键(Idempotency Key):客户端在每次