原写于2010-12-11
Java并发,对于共享资源的控制,是一个复杂的事情,比如:同步等。 ThreadLocal 为这个问题提供另外一种解决方案,其实根本的原理“用空间换时间”。
一、结构图
二、源码阅读
关注切入点:set(),get()方法
1.set()方法
结论:对ThreadLocal的操作,实际委托给当前Thread,每个Thread都会有自己独立的ThreadLocalMap实例,存储的仓库是Entry[] table;Entry的key为ThreadLocal,value为存储内容;因此在并发环境下,对ThreadLocal的set或get,不会有任何问题。
2.get方法
遗留问题
1.Thread.threadLocals 什么时候实例化?线程实例化时吗?答:第一次set时,会判断是否为null,若为null,初始化。
2.ThreadLocalMap.replaceStaleEntry(key, value, i); 做了什么?全清洗stale对象;存放当前对象在发现的第一个stale位置。
3.ThreadLocalMap.getEntryAfterMiss(ThreadLocal key, int i, Entry e)作用
查找没有存放在hash计算出index位置的元素(为什么出现此情况?如果发现已经被gc的内容时,会直接把当前对象存放在已被gc对象的位置)此做法,与Map方式,有区别?Map策略:a、相同hash&key,覆盖value; b、相同hash,key不同,当前元素做为单向链的第一个元素,原来第一个元素做为当前元素的下一个。ThreadLocalMap原理,是不存在b情况,以ThreadLocal作为key,ThreadLocal 有threadLocalHashCode 属性唯一的标识一个实例,Entry[]数组的偏移,是通过threadLocalHashCode & (length-1)计算,因为不存在:threadLocalHashCode相同,但取出存方在Entry中key不同(key是ThreadLocal实例).
三、应用场景
public class SqlMapClientImpl { protected ThreadLocal localSqlMapSession = new ThreadLocal(); public int delete(String id) throws SQLException { return getLocalSqlMapSession().delete(id); //所有操作,首先getLocalSqlMapSession()获取SqlMapSessionImpl } protected SqlMapSessionImpl getLocalSqlMapSession() { SqlMapSessionImpl sqlMapSession = (SqlMapSessionImpl) localSqlMapSession.get(); //从ThreadLocal获取SqlMapSessionImpl if (sqlMapSession == null || sqlMapSession.isClosed()) { sqlMapSession = new SqlMapSessionImpl(this); localSqlMapSession.set(sqlMapSession); //存入ThreadLocal } return sqlMapSession; } }
结论:当SqlMapClient为单实例时,多个请求操作,也就是多个线程操作,此时获取的SqlMapSessionImpl是针对当前线程的;在servlet容器,使用一个线程池服务请求,所以SqlMapSessionImpl是能被复用,提高效率。
相关推荐
**线程局部变量(ThreadLocal)是Java编程中一个非常重要的工具类,它在多线程环境下提供了线程安全的数据存储。ThreadLocal并不是一个变量,而是一个类,它为每个线程都创建了一个独立的变量副本,使得每个线程都...
ThreadLocal 中内存泄漏和数据丢失问题的问题浅析及解决方案 ThreadLocal 是 Java 中的一种线程本地存储机制,它可以解决线程之间的数据传递问题。然而,在使用 ThreadLocal 时,可能会出现内存泄漏和数据丢失问题...
ThreadLocal是Java编程语言中的一个类,用于在多线程环境中提供线程局部变量。它是一种特殊类型的变量,每个线程都有自己的副本,互不影响,从而实现线程间数据隔离。ThreadLocal通常被用来解决线程共享数据时可能...
在 `LeakingServlet` 的 `doGet` 方法中,如果 `ThreadLocal` 没有设置值,那么会创建一个新的 `MyCounter` 并设置到 `ThreadLocal` 中。关键在于,一旦 `MyCounter` 被设置到 `ThreadLocal`,那么它将与当前线程...
### 正确理解ThreadLocal:深入解析其工作原理与应用场景 #### 一、ThreadLocal的基本概念 `ThreadLocal`是Java平台提供的一种线程局部变量的解决方案,它为每一个使用该变量的线程都提供了独立的变量副本,使得每...
Java中的ThreadLocal是一个非常重要的工具类,它在多线程编程中扮演着独特角色,尤其在处理线程间数据隔离和共享时。ThreadLocal不是线程本身,而是为每个线程提供一个独立的变量副本,使得每个线程都可以独立地改变...
ThreadLocal 整理 ThreadLocal 是 Java 中的一个重要组件,它能够在每个线程中保持独立的副本。这个功能是通过 Thread 类中的 threadLocals 属性来实现的,这个属性实际上是一个 Entry 数组,其中的每个 Entry 都...
Java事务和ThreadLocal是两种在Java编程中至关重要的概念,它们分别用于处理多线程环境下的数据一致性问题和提供线程局部变量。 首先,我们来深入理解Java事务。在数据库操作中,事务是一系列操作的集合,这些操作...
理解ThreadLocal 理解ThreadLocal 理解ThreadLocal 理解ThreadLocal
由于提供的文件内容包含了大量的OCR扫描错误和重复内容,我将尽力根据现有的信息,提供一个关于ThreadLocal的知识点总结。如果出现无法理解的片段,我会尝试根据上下文进行合理推断并忽略错误的部分。 在Java中,...
### Java中ThreadLocal详解 #### 一、ThreadLocal概述 在Java多线程编程中,`ThreadLocal`是一个非常重要的工具类,它提供了一种在每个线程内部存储线程私有实例的方法。通常情况下,当多个线程共享某个变量时,...
ThreadLocal是Java编程中一种非常特殊的变量类型,它主要用于在多线程环境下为每个线程提供独立的变量副本,从而避免了线程间的数据共享和冲突。然而,ThreadLocal在理解和使用过程中容易产生一些误区,这里我们将...
**线程局部变量(ThreadLocal)** 在Java编程中,`ThreadLocal`是一个非常重要的工具类,它用于在多线程环境中提供线程安全的局部变量。`ThreadLocal`并不是一个线程,而是一个线程局部变量的容器,每个线程都有自己...
**线程局部变量(ThreadLocal)是Java编程中一个非常重要的概念,主要用于在多线程环境中为每个线程提供独立的变量副本。ThreadLocal不是一种数据结构,而是一种解决线程间共享数据的方式,它提供了线程安全的局部...
本资料主要聚焦于两种设计模式以及Java中的ThreadLocal特性。 首先,我们来探讨单例模式。单例模式是一种确保一个类只有一个实例,并提供全局访问点的设计模式。在Java中,通常通过私有构造函数、静态工厂方法或...
**ThreadLocal概述** ThreadLocal是Java中的一个线程局部变量类,它为每个线程创建了一个独立的变量副本。这意味着每个线程都有自己的ThreadLocal变量,互不干扰,提供了线程安全的数据存储方式。ThreadLocal通常...
在Java编程中,ThreadLocal是线程局部变量的类,它提供了一种在多线程环境中为每个线程创建和维护独立副本的机制。ThreadLocal主要用于解决线程间的数据隔离问题,确保各线程拥有自己的变量副本,避免了数据共享带来...
ThreadLocal是Java编程语言中的一个线程局部变量类,它为每个线程提供了一个独立的变量副本,使得每个线程可以独立地改变自己的副本,而不会影响其他线程所对应的副本。这个特性在多线程环境下处理并发问题时非常...