原写于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中内存泄漏和数据丢失问题的问题浅析及解决方案.docx
ThreadLocal应用示例及理解,这个写了相关的示例,可以参考一下。
ThreadLocal入门教程。 讲解了线程安全和ThreadLocal的使用的基本知识。
ThreadLocal
理解ThreadLocal 理解ThreadLocal 理解ThreadLocal 理解ThreadLocal
学习ThreadLocal,了解其中的原理,以及学习其中的优点!避免坑点!!
正确理解ThreadLocal.pdf
DbUTils中用ThreadLocal类
主要介绍ThreadLocal的原理,实例分析以及注意事项
java 简单的ThreadLocal示例
ThreadLocal的几种误区ThreadLocal的几种误区ThreadLocal的几种误区
本例以序列号生成的程序为例,展示ThreadLocal的使用
ThreadLocal保证一个类的实例变量在各个线程中都有一份单独的拷贝, 从而不会影响其他线程中的实例变量
详解java底层实现原理,ThreadLocal底层实现的数据结构,为什么不会导致内存泄露
设计模式及ThreadLocal详细讲解资料,想要学习java或者提升自己技术的同学可以下载观看
JDBC事务的封装和Threadlocal实例,参考博客:http://blog.csdn.net/daijin888888/article/details/50988053
Synchronized与ThreadLocal
ThreadLocal源码分析,主要有ThreadLocal源码以及ThreadLocal的内部结构在jdk8前后的变化
ThreadLocal的基本原理,核心机制,源码,ThreadLocal在分布式架构中的应用,ThreadLocal在基础架构,开源中间件,使用非常广泛,建议掌握。