首页 > 其他分享 >ThreadLocal 与 synchronized 区别

ThreadLocal 与 synchronized 区别

时间:2023-06-08 21:03:13浏览次数:57  
标签:set Java 变量 Thread 区别 ThreadLocal synchronized 线程



老实说,从看到这个帖子的题目开始,就觉得帖子的作者估计是在概念上有所混淆了,于是乎想写个咚咚,同大家分享一下自己的心得。

帖子上,讨论的人很多,高手不乏,各抒己见,但不知新手们看明白没有,因此,这里偶以最简洁列表方式来说一说相关问题。

1.区别ThreadLocal 与 synchronized

  • ThreadLocal是一个线程隔离(或者说是线程安全)的变量存储的管理实体(注意:不是存储用的),它以Java类方式表现;
  • synchronized是Java的一个保留字,只是一个代码标识符,它依靠JVM的锁机制来实现临界区的函数、变量在CPU运行访问中的原子性。

两者的性质、表现及设计初衷不同,因此没有可比较性。



2.理解ThreadLocal中提到的变量副本


事实上,我们向ThreadLocal中set的变量不是由ThreadLocal来存储的,而是Thread线程对象自身保存。当用户调用 ThreadLocal对象的set(Object o)时,该方法则通过Thread.currentThread()获取当前线程,将变量存入Thread中的一个Map内,而Map的Key就是当前的 ThreadLocal实例。请看源码,这是最主要的两个函数,能看出ThreadLocal与Thread的调用关系:


Java代码

1. public void set(T value) {  
2.         Thread t = Thread.currentThread();  
3.         ThreadLocalMap map = getMap(t);  
4.         if (map != null)  
5.             map.set(this, value);  
6.         else  
7.             createMap(t, value);  
8. }  
9.   
10. ThreadLocalMap getMap(Thread t) {  
11.         return t.threadLocals;  
12. }



(有兴趣的朋友可以阅读Java的ThreadLocal源码)因此,我们可以知道,所谓的变量副本,即是对Object Reference(对象引用)的拷贝。



3.理解Thread和 ThreadLocal对变量的引用关系


实际上Thread和ThreadLocal对变量引用关系就像是坐标系中的X轴和Y轴,是从两个维度上来组织对变量的引用的。


  • 首先说Thread。 我们知道一个ThreadOne的执行会贯穿多个方法MethodA、MethodB、MethodC这些方法可能分布于不同的类实例。假设,这些方法分 别使用了ThreadLocalA、ThreadLocalB、ThreadLocalC来保存线程本地变量,那么这些变量都存于ThreadOne的 Map中,并使用各自的ThreadLocal实例作为key。 因此,可以认为,借助ThreanLocal的set方法,在X轴上,Thread横向关联同一线程上下文中来自多个Method的变量引用副本。


 

ThreadLocal 与 synchronized 区别_线程安全



  • 接着说ThreadLocal。 一个MethodA中的X变量将被多个线程ThreadOne、ThreadTwo、ThreadThree所访问。假设MethodA使用 ThreadLocal存储X,通过set方法,以ThreadLocal作为key值,将不同线程来访时的不同的变量值引用保存于ThreadOne、 ThreadTwo、ThreadThree的各自线程上下文中,确保每个线程有自己的一个变量值。因此,可以认为,ThreadLocal是以 Method为Y轴,纵向关联了处于同一方法中的不同线程上的变量。


 

ThreadLocal 与 synchronized 区别_线程安全_02



希望能对大家有所帮助,这样可以少走很多弯路哦。

标签:set,Java,变量,Thread,区别,ThreadLocal,synchronized,线程
From: https://blog.51cto.com/u_16065168/6443269

相关文章

  • 【转载】CXF spring jaxws:endpoint jaxws:server 区别 与 关系
    通过spring配置实现webservice的配置有两种,一种是jaxws:endpoint ,另外一种是jaxws:server。百度上没查到相关区别,又由于本人没有跟代码,所以又google了一下,才找到:First,theyareallfortheserversideconfiguration.Second,jaxws:endpointiscomingfromJAXWSAPI,a......
  • 显卡,CPU,GPU和CUDA的关系与区别
    (1)显卡:显卡全称显示接口卡,又称显示适配器,是计算机最基本配置、最重要的配件之一。就像电脑联网需要网卡,主机里的数据要显示在屏幕上就需要显卡。因此,显卡是电脑进行数模信号转换的设备,承担输出显示图形的任务。具体来说,显卡接在电脑主板上,它将电脑的数字信号转换成模拟信号让显示器......
  • 常见五类/超五类、六类/超六类、七类网线的区别
    常见五类/超五类、六类/超六类、七类网线的区别双绞线:双绞线的英文名字叫TwistedPair。是综合布线工程中最常用的一种传输介质。双绞线可分为屏蔽双绞线(STP=ShieldedTwistedPair)和非屏蔽双绞线(UTP=UnshieldedTwistedPair)。STP(屏蔽双绞线)的双绞线内有一层或几层屏蔽......
  • icache的dcache区别
    iCache是指指令缓存,DCache是指数据缓存。iCache是专门用于存储指令的高速缓存,DCache是用于存储数据的高速缓存。iCache用于存储指令,在CPU执行时将指令从iCache中读取,以提高指令执行的速度;DCache则用于存储数据,如变量、数组等,以避免频繁从内存中读取数据,提高程序执行效率。iCache和......
  • 【C#】抽象类和接口的区别和使用场景
    http://www.cftea.com/c/2012/03/5522.asp抽象类可以有构造吗:https://blog.csdn.net/weixin_46879188/article/details/122063289抽象类的构造函数用来初始化抽象类的一些字段,而这一切都在抽象类的派生类实例化之前发生。......
  • SNMP学习笔记之SNMP报文以及不同版本(SNMPv1、v2c、v3)的区别
    SNMP学习笔记之SNMP报文以及不同版本(SNMPv1、v2c、v3)的区别本篇文章将重点分析SNMP报文,并对不同版本(SNMPv1、v2c、v3)进行区别!四、SNMP协议数据单元在SNMP管理中,管理站(NMS)和代理(Agent)之间交换的管理信息构成了SNMP报文,报文的基本格式如下图1:        ......
  • gitlab和github的区别
    github:支持新分支和主分支合并,快速部署,出现问题可以恢复上一版本,是开发人员选择CI\CD的并行集成,一般会选择第三方CI工具,如Jenkins,CircleCI,TranvisCIgitlab:看重安全性,用户在master创建分支,合并时就需要多次审查,集成了Devops流程,持续集成\持续交付。中小型项目可以选择免费版。......
  • 冒烟测试 VS 回归测试:区别与应用
    冒烟测试冒烟测试是软件测试中的一种快速、简单、基本的测试,也称为可行性测试、快速测试或验证性测试。其主要目的是确保新构建的软件版本能够基本运行,以确定是否值得进行更详细的测试和验证,避免在后期测试过程中花费过多时间和人力资源。冒烟测试通常在软件开发的早期进行,例如在每......
  • 拨号获取IP和HTTP代理有什么区别
    在网络通信中,IP地址和HTTP代理都扮演着非常重要的角色。而拨号获取IP与HTTP代理虽然都可以隐藏用户的真实IP地址,但是它们本质上有着很大的区别。下面我们来详细介绍一下他们的区别。一、拨号获取IP拨号获取IP,是指用户通过拨打互联网服务提供商(ISP)的电话线路,建立网络连......
  • 方芳:大兴调查和田野调查的区别
    武汉市江夏区交通局武汉市江夏区公路局  武汉市江夏区公路建筑工程公司武汉市江夏城投集团有限公司武汉江夏路桥工程总公司 武汉工程大学 土木工程与建筑学院    方芳    15927602711 大兴调查研究是指在社会科学研究中,通过对社会现象进行广泛的问......