- 浏览: 81484 次
- 性别:
- 来自: 广州
文章分类
最新评论
-
撼地神牛:
你这服务 ,还是多线程的啊! 真晕!
用java.nio.*进行网络编程 -
f_zongjian:
多行注释符:/*注释*/
mysql注释符 -
lixjluck:
这个不是原理和使用吧,误导。。。
Java NIO原理和使用 -
sunjilu05:
有没有办法在两台内网的机器之间通过第三方服务器的牵引,建立一个 ...
Java Socket编程 -
xombat:
关键是如果发生这样一种情况,问题就会很复杂:相邻两点之间是多条 ...
最短路径算法
最近由于需要用到ThreadLocal,在网上搜索了一些相关资料,发现对ThreadLocal经常会有下面几种误解
一、ThreadLocal是java线程的一个实现
ThreadLocal的确是和java线程有关,不过它并不是java线程的一个实现,它只是用来维护本地变量。针对每个线程,提供自己的变量版本,主要是为了避免线程冲突,每个线程维护自己的版本。彼此独立,修改不会影响到对方。
/**
* 序列号
*/
public class SerialNum {
// The next serial number to be assigned
private static int nextSerialNum = 0;
private static ThreadLocal serialNum = new ThreadLocal() {
protected synchronized Object initialValue() {
return new Integer(nextSerialNum++);
}
};
public static int get() {
return ((Integer) (serialNum.get())).intValue();
}
public static void main(String[] args) {
for (int i = 0; i < 5; i++) {
new TestThread(i).start();
}
}
}
class TestThread extends Thread {
public TestThread(int i) {
super("TestThread " + i);
}
public void run() {
int threadSerialNum = SerialNum.get();
System.out.println(this.getName() + ",的序列号=" + threadSerialNum);
int threadSerialNum2 = SerialNum.get();
System.out.println(this.getName() + ",的序列号2=" + threadSerialNum2);
}
}
运行结果:
TestThread 0,的序列号=0
TestThread 1,的序列号=1
TestThread 2,的序列号=2
TestThread 4,的序列号=3
TestThread 3,的序列号=4
TestThread 0,的序列号2=0
TestThread 1,的序列号2=1
TestThread 2,的序列号2=2
TestThread 4,的序列号2=3
TestThread 3,的序列号2=4
二、ThreadLocal是相对于每个session的
ThreadLocal顾名思义,是针对线程。在java web编程上,每个用户从开始到会话结束,都有自己的一个session标识。但是ThreadLocal并不是在会话层上。其实,Threadlocal是独立于用户session的。它是一种服务器端行为,当服务器每生成一个新的线程时,就会维护自己的ThreadLocal。对于这个误解,个人认为应该是开发人员在本地基于一些应用服务器测试的结果。众所周知,一般的应用服务器都会维护一套线程池,也就是说,对于每次访问,并不一定就新生成一个线程。而是自己有一个线程缓存池。对于访问,先从缓存池里面找到已有的线程,如果已经用光,才去新生成新的线程。所以,由于开发人员自己在测试时,一般只有他自己在测,这样服务器的负担很小,这样导致每次访问可能是共用同样一个线程,导致会有这样的误解:每个session有一个ThreadLocal
三、ThreadLocal是相对于每个线程的,用户每次访问会有新的ThreadLocal
理论上来说,ThreadLocal是的确是相对于每个线程,每个线程会有自己的ThreadLocal。但是上面已经讲到,一般的应用服务器都会维护一套线程池。因此,不同用户访问,可能会接受到同样的线程。因此,在做基于TheadLocal时,需要谨慎,避免出现ThreadLocal变量的缓存,导致其他线程访问到本线程变量
四、对每个用户访问,ThreadLocal可以多用
可以说,ThreadLocal是一把双刃剑,用得来的话可以起到非常好的效果。但是,ThreadLocal如果用得不好,就会跟全局变量一样。代码不能重用,不能独立测试。因为,一些本来可以重用的类,现在依赖于ThreadLocal变量。如果在其他没有ThreadLocal场合,这些类就变得不可用了。个人觉得ThreadLocal用得很好的几个应用场合,值得参考
1、存放当前session用户:quake want的jert
2、存放一些context变量,比如webwork的ActionContext
3、存放session,比如Spring hibernate orm的session
发表评论
-
你真的理解了继承和多态吗?
2008-08-12 09:52 921http://www.blogjava.net/sean/ar ... -
浅析Java语言中的内部类
2008-05-23 09:39 676文章1: http://www.enet.com.cn/art ... -
Java同步机制浅谈
2008-05-09 23:27 673http://dev.csdn.net/article/71/ ... -
日历类的小例子
2008-04-16 23:10 817Calendar cal = Calendar.getInst ... -
Java虚拟机参数配置说明
2008-03-17 17:09 1382转载:http://www.cnblogs.com/huqin ... -
JAVA教程:解析Java的多线程机制
2008-02-29 09:15 702转载:http://tech.163.com/05/1020/ ... -
Java字符编码转换过程说明
2008-01-08 18:29 822转载 http://blog.csdn.net/heh ... -
浅析Java多线程编程中的高级技术
2007-12-26 09:19 705转载:http://www.1-100.org/other/1 ... -
Java对象的强、软、弱和虚引用
2007-09-10 23:22 716转载:http://java.chinaitlab.com/o ... -
Java异常学习心得
2007-09-07 10:52 947转载:http://columnist.china ... -
Hibernate存取Clob对象
2007-09-05 11:04 843转载:http://www.amuhouse.com/link ... -
Mbean的管理接口
2007-08-30 16:29 1236转载:http://www.51chm.com/spring/ ... -
JDK1.5新特性介绍
2007-08-30 15:56 823转载:http://www.yesky.com/263/185 ... -
实现非阻塞套接字的一种简单方法
2007-08-29 10:09 1581转载:http://www.ibm.com/dev ... -
Java NIO原理和使用
2007-08-28 15:05 2943转载:http://www.jdon.com/co ... -
一篇不错的介绍Java Socket编程的文章
2007-08-28 14:31 967转载:http://java.ccidnet.co ... -
Java Socket编程 Socket传输模式
2007-08-28 14:06 957转载:http://www.bitscn.com/java/n ... -
Java Socket编程
2007-08-28 14:04 1994转载:http://www.bitscn.com/ ... -
用java.nio.*进行网络编程
2007-08-27 11:36 1435转载:http://java.chinaitlab ... -
AOP是什么?
2007-08-23 23:19 808转载:http://www.jdon.com/AOPdesig ...
相关推荐
**线程局部变量(ThreadLocal)是Java编程中一个非常重要的工具类,它在多线程环境下提供了线程安全的数据存储。ThreadLocal并不是一个变量,而是一个类,它为每个线程都创建了一个独立的变量副本,使得每个线程都...
它是一种特殊类型的变量,每个线程都有自己的副本,互不影响,从而实现线程间数据隔离。ThreadLocal通常被用来解决线程共享数据时可能出现的并发问题,避免了使用synchronized关键字进行同步控制的复杂性。 在Java...
理解ThreadLocal 理解ThreadLocal 理解ThreadLocal 理解ThreadLocal
Java事务和ThreadLocal是两种在Java编程中至关重要的概念,它们分别用于处理多线程环境下的数据一致性问题和提供线程局部变量。 首先,我们来深入理解Java事务。在数据库操作中,事务是一系列操作的集合,这些操作...
在 `LeakingServlet` 的 `doGet` 方法中,如果 `ThreadLocal` 没有设置值,那么会创建一个新的 `MyCounter` 并设置到 `ThreadLocal` 中。关键在于,一旦 `MyCounter` 被设置到 `ThreadLocal`,那么它将与当前线程...
`ThreadLocal`是Java平台提供的一种线程局部变量的解决方案,它为每一个使用该变量的线程都提供了独立的变量副本,使得每一个线程都可以独立地改变自己的副本,而不会影响其它线程所对应的副本。这不同于普通的静态...
在多线程环境中,当每个线程需要有自己的状态(如计数器),ThreadLocal提供了一种优雅的解决方案。 尽管ThreadLocal在很多场景下都非常有用,但它也有一些潜在的问题需要注意,比如内存泄漏和过度使用可能导致...
ThreadLocal 整理 ThreadLocal 是 Java 中的一个重要组件,它能够在每个线程中保持独立的副本。这个功能是通过 Thread 类中的 threadLocals 属性来实现的,这个属性实际上是一个 Entry 数组,其中的每个 Entry 都...
ThreadLocal的工作原理主要基于以下几点: - **内部类ThreadLocalMap**:ThreadLocal在每个线程内部维护了一个名为ThreadLocalMap的哈希映射表,这个表的键是ThreadLocal对象,值是线程局部变量的实际值。这样,每...
下面我们将深入探讨`ThreadLocal`的工作原理、使用场景以及常见误区。 `ThreadLocal`类的主要方法有以下几个: 1. `void set(T value)`:设置当前线程的线程局部变量的值。 2. `T get()`:返回当前线程的线程局部...
本资料主要聚焦于两种设计模式以及Java中的ThreadLocal特性。 首先,我们来探讨单例模式。单例模式是一种确保一个类只有一个实例,并提供全局访问点的设计模式。在Java中,通常通过私有构造函数、静态工厂方法或...
而`ThreadLocal`则提供了另一种思路:为每个使用该变量的线程分配独立的副本,这样一来,每个线程拥有自己的变量副本,互不影响,从而避免了线程安全问题。 #### 二、ThreadLocal的数据结构及实现原理 `...
2. 并发编程:ThreadLocal是解决并发问题的一种策略,它提供了一种避免共享状态的方式,减少了锁的使用。 3. 内存管理:了解Java的内存模型和垃圾回收机制,才能理解ThreadLocal的内存泄漏风险和弱引用的作用。 4. ...
学习ThreadLocal,了解其中的原理,以及学习其中的优点!避免坑点!!
**线程局部变量(ThreadLocal)** 在Java编程中,`ThreadLocal`是一个非常重要的工具类,它用于在多线程环境中提供线程安全的局部变量。`ThreadLocal`并不是一个线程,而是一个线程局部变量的容器,每个线程都有自己...
在Java编程中,ThreadLocal是线程局部变量的类,它提供了一种在多线程环境中为每个线程创建和维护独立副本的机制。ThreadLocal主要用于解决线程间的数据隔离问题,确保各线程拥有自己的变量副本,避免了数据共享带来...