java的ThreadLocal是否能被其他线程访问到?里面的机制是怎么样的
threadlocal是针对 per-thread的,不会被其他线程并发访问。
threadlocal变量和单个线程关联,简单来讲,类似于(具体可参考jdk源码):
[code="java"]public class FakeThreadLocal {
private final Map values = new HashMap();
public T get() {
return values.get(Thread.currentThread());
}
public void set(T t) {
values.put(Thread.currentThread(), t);
}
}
[/code]
应用场景1,创建一个 SimpleDateFormat实例的开销比较昂贵,解析字符串时间时频繁创建生命周期短暂的实例导致性能低下。即使将 SimpleDateFormat定义为静态类变量,貌似能解决这个问题,但是SimpleDateFormat是非线程安全的,同样存在问题,如果用 ‘synchronized’线程同步同样面临问题,同步导致性能下降(线程之间序列化的获取SimpleDateFormat实例)。
使用Threadlocal解决了此问题,对于每个线程SimpleDateFormat不存在影响他们之间协作的状态,为每个线程创建一个SimpleDateFormat变量的拷贝或者叫做副本。
[code="java"]public class Test
{
// SimpleDateFormat is not thread-safe, so give one to each thread
private static final ThreadLocal formatter = new ThreadLocal(){
@Override
protected SimpleDateFormat initialValue()
{
return new SimpleDateFormat("yyyyMMdd HHmm");
}
};
public String formatIt(Date date)
{
return formatter.get().format(date);
}
}[/code]
应用场景2,在servlet/filter中保存初始状态,以便解决并发问题。
应用场景3,在一些框架中保存和当前线程有关的上下文。
每个线程有个单独的ThreadLocal,用于解决变量线程不安全的问题,所以不能被访问到。机制就是把当前线程作为key,value存储你要存储的东西