题记:一直对ThreadLocal疑惑,听完facebook大牛演讲后,总结点东西。
一、ThreadLocal的作用,整体结构
二、源代码简单分析
1.set方法
2.get方法
三、使用场景实例 ibatis SqlMapClientImp
后记:折腾半天,文章的样式也调整不好,打包上传。但愿能帮到别人。
http://www.blogjava.net/Files/shijian/ThreadLocal.rar [请用“web版式视图”阅读]
遗留问题:
1.Thread的ThreadLocalMap threadLocals 属性什么时候实例化 ? 线程实例化时吗 ?
答:第一次set时,会判断是否为null,若为null,初始化。
2.ThreadLocalMap replaceStaleEntry(key,
value, i); 做了什么 ?
答:全清洗stale对象;存放当前对象在发现的第一个stale位置。因为Entry是继承WeakRerfence,任何一次的垃圾收集,都会导致其引用的对象被回收。
4.与Map方式的一些区别 ?
Map策略:a、相同hash&key,覆盖value; b、相同hash,key不同,当前元素做为单向链的第一个元素,原来第一个元素做为当前元素的下一个。
ThreadLocalMap策略:a相同,是不存在b情况;以ThreadLocal作为key,ThreadLocal的threadLocalHashCode由原子AtomicInteger计算getAndAdd(0x61c88647)得到;在Entry[]数组的位置,通过threadLocalHashCode
& (length-1)计算;对于b情况,继续查找Entry[]数组的下一个位置,是否可存放(key相同或null);当size>=threshold(len*2/3)做resize=oldLen*2.
3.ThreadLocalMap getEntryAfterMiss(ThreadLocal key, int i, Entry e);
答:作用,查找没有存放在hash计算出index位置的元素。为什么出现此情况?见4,由ThreadLocalMap策略决定.