- 浏览: 2290120 次
- 性别:
- 来自: 成都
文章分类
- 全部博客 (357)
- J2EE (49)
- JavaScript (40)
- Spring (19)
- Struts (5)
- CSS (8)
- Hibernate (16)
- Java (67)
- DWR (4)
- JSON (3)
- XFIRE (1)
- Tomcat (1)
- Ant (2)
- 设计模式 (2)
- 经典收藏 (2)
- JSP (10)
- Linux (0)
- WebLogic (11)
- myeclipse (13)
- Buffalo (4)
- 文件上传相关 (1)
- oracle (33)
- html (6)
- JSTL (3)
- SVN (2)
- GIT (1)
- 孙卫琴(Java网络编程精解) (1)
- DOM4J (2)
- Swing (1)
- AJAX (1)
- Eclipse (5)
- 日志组件 (3)
- PowerDesigner (1)
- Jquery (22)
- IT技术开发相关网址 (1)
- Nutz (1)
- 其它 (1)
- Velocity (3)
- WebService (1)
- MySql (2)
- Android (1)
- Maven (2)
- Quartz (11)
- Lucene (1)
- springsource (1)
- Junit (1)
- Activiti (0)
最新评论
-
yzlseu:
拼凑,没有营养
Activiti进阶—分配组任务 -
zhangsenhao:
非常赞!代码很清楚
SpringMVC3.0+MyIbatis3.0(分页示例) -
xiamw2000:
分页写得不对,应该是 : order by ${orderNa ...
SpringMVC3.0+MyIbatis3.0(分页示例) -
sheertewtw:
...
SpringMVC:上传与下载 -
kingtoon:
...
XSS之xssprotect
参考资料
1 深入研究java.lang.ThreadLocal类
http://lavasoft.blog.51cto.com/62575/51926
2 java中ThreadLocal类的使用
http://www.niwota.com/submsg/1551983/
3 Java ThreadLocal介绍
http://www.blogjava.net/Ericzhang5231/articles/JavaThreadlocal.html
4 Java中ThreadLocal的设计与使用
http://www.yesky.com/266/1882766.shtml
一 ThreadLocal介绍
ThreadLocal是Thread local variable(线程局部变量),为每一个使用该变量的线程都提供一个变量值的副本,是每一个线程都可以独立地改变自己的副本,而不会和其它线程的副本冲突。从线程的角度看,就好像每一个线程都完全拥有该变量.
二 ThreadLocal与synchronized的区别
ThreadLocal和线程同步机制都是为了解决多线程中相同变量的访问冲突问题
Synchronized用于在多个线程间通信时能够获得数据共享,它利用锁的机制,使变量或代码块在某一时该只能被一个线程访问,采用了“以时间换空间”的方式,仅提供一份变量,让不同的线程排队访问,编写比ThreadLocal更加复杂。
ThreadLocal则用于线程间的数据隔离,主要解决多线程中数据数据因并发产生不一致问题同,它采用了“以空间换时间”的方式。为每一个线程都提供了一份变量,因此可以同时访问而互不影响.
三 具体示例
输出结果如下:
从结果中可以查看到,每个线程之间的数据是完全隔离的,互不影响
总结:ThreadLocal是解决线程安全问题一个很好的思路,它通过为每个线程提供一个独立的变量副本解决了变量并发访问的冲突问题。在很多情况下, ThreadLocal比直接使用synchronized同步机制解决线程安全问题更简单,更方便,且结果程序拥有更高的并发性.
1 深入研究java.lang.ThreadLocal类
http://lavasoft.blog.51cto.com/62575/51926
2 java中ThreadLocal类的使用
http://www.niwota.com/submsg/1551983/
3 Java ThreadLocal介绍
http://www.blogjava.net/Ericzhang5231/articles/JavaThreadlocal.html
4 Java中ThreadLocal的设计与使用
http://www.yesky.com/266/1882766.shtml
一 ThreadLocal介绍
ThreadLocal是Thread local variable(线程局部变量),为每一个使用该变量的线程都提供一个变量值的副本,是每一个线程都可以独立地改变自己的副本,而不会和其它线程的副本冲突。从线程的角度看,就好像每一个线程都完全拥有该变量.
二 ThreadLocal与synchronized的区别
ThreadLocal和线程同步机制都是为了解决多线程中相同变量的访问冲突问题
Synchronized用于在多个线程间通信时能够获得数据共享,它利用锁的机制,使变量或代码块在某一时该只能被一个线程访问,采用了“以时间换空间”的方式,仅提供一份变量,让不同的线程排队访问,编写比ThreadLocal更加复杂。
ThreadLocal则用于线程间的数据隔离,主要解决多线程中数据数据因并发产生不一致问题同,它采用了“以空间换时间”的方式。为每一个线程都提供了一份变量,因此可以同时访问而互不影响.
三 具体示例
import java.util.Random; public class ThreadLocalTest { public static void main(String[] args) { init(); } private static void init() { for (int i = 0; i < 2; i++) { new Thread(new Runnable() { @Override public void run() { int num = new Random().nextInt(); System.out.println(Thread.currentThread().getName()+",main: " + num); User.getInstance().setAge(num); User.getInstance().setName("name"+num); new TaskA().show(); new TaskB().show(); } }).start(); } } static class TaskA { public void show() { int num = User.getInstance().getAge(); String name = User.getInstance().getName(); System.out.println("A num: " + num + ",name: " + name); } } static class TaskB { public void show() { int num = User.getInstance().getAge(); String name = User.getInstance().getName(); System.out.println("B num: " + num + ",name: " + name); } } } class User{ private String name; private int age; private static ThreadLocal<User> threadLocal = new ThreadLocal<User>(); public static User getInstance(){ User user = threadLocal.get(); if(null == user){ user = new User(); threadLocal.set(user); } return user; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } }
输出结果如下:
Thread-0,main: 1833403530 A num: 1833403530,name: name1833403530 B num: 1833403530,name: name1833403530 Thread-1,main: 1589097477 A num: 1589097477,name: name1589097477 B num: 1589097477,name: name1589097477
从结果中可以查看到,每个线程之间的数据是完全隔离的,互不影响
总结:ThreadLocal是解决线程安全问题一个很好的思路,它通过为每个线程提供一个独立的变量副本解决了变量并发访问的冲突问题。在很多情况下, ThreadLocal比直接使用synchronized同步机制解决线程安全问题更简单,更方便,且结果程序拥有更高的并发性.
发表评论
-
java json-lib & jQuery & jsonp
2016-06-30 11:31 831参考链接: 1、http://hanqunfeng.iteye ... -
随机分配算法(Intege)
2016-01-08 13:05 5201参考资料: http://blog.csdn.net/yaer ... -
XSS之xssprotect
2012-12-07 23:03 29495参考资料 1 跨网站脚本 ... -
Java之Thread(线程题)
2011-10-31 12:33 1977特别说明:java线程相关的参考了张孝祥老师的代码 参考资料 ... -
Java之synchronized,wait,notify结合运用示例
2011-10-26 11:54 5939场景一:要求二个线程各 ... -
Java之synchronized深入应用
2011-10-23 08:03 1948参考资料 1 java synchronized详解 http ... -
Java之Timer入门
2011-10-11 15:32 1699参考资料 1 java中timer用 ... -
Java之线程(匿名内部类)
2011-10-10 16:36 164381 Thread对象 Thread t = new Thr ... -
Java之线程(join)
2011-10-10 15:39 1485运用场景:多个线程之间 ... -
Java之线程(synchronized,wait(),notify(),notifyAll())
2011-10-10 15:03 3256参考资料 Java多线程入门大全(适用于有一定基础者) htt ... -
Java之线程(sleep,线程名)
2011-10-10 13:09 9719参考资料 1 Java线程:创建与启动 http://lava ... -
Java之线程入门
2011-10-10 11:11 1538参考资料 1 Java线程:概 ... -
java之表反向生成类
2011-09-23 16:41 3487环境:XP+JDK1.5+Oracle10g 注意事项 1 请 ... -
java之线程, NIO学习资料
2011-09-19 12:13 1134Concurrent In Java 6 第一部分 集合 ... -
Java之BigDecimal
2011-09-15 10:12 18036参考资料 1 java.math.BigDecimal的用法 ... -
java.lang.OutOfMemoryError异常解决方法
2011-08-27 16:47 2114转载:java.lang.OutOfMemoryError异常 ... -
Jcom之jp.ne.so_net.ga2.no_ji.jcom.JComException: createInstance() failed HRESULT=
2011-08-25 12:33 11748参考资料 java应用jcom将word转pdf http:/ ... -
Quartz之AnnualCalendar
2011-08-11 17:14 5823问题1 我想排除一年中 ... -
Quartz之InterruptableJob
2011-08-11 11:03 11783问题1 由于业务需要,停止Quartz中正在执行的任务 Qua ... -
Quartz之JobExecutionException
2011-08-11 10:06 13416问题1 如果你的任务执 ...
相关推荐
应优先考虑其他同步机制,如`synchronized`关键字或`java.util.concurrent`包中的工具类。 2. **及时清理**:确保在不再使用ThreadLocal时调用`remove()`,以防止内存泄漏。 3. **谨慎使用在长生命周期线程中**:如...
ThreadLocal是Java中用于线程局部变量的一个工具类,它的工作原理主要体现在如何在不同的线程之间隔离变量的副本,确保每个线程拥有自己的独立数据。这个设计模式在多线程编程中尤其有用,因为它避免了传统的同步...
### Synchronized与ThreadLocal #### 一、Synchronized机制详解 **Synchronized** 是 Java 中一个非常重要的关键字,主要...这正是 ThreadLocal 的强大之处,它提供了一种简单而高效的方式来处理线程局部变量的问题。
java 中ThreadLocal 的正确用法 ThreadLocal 是 Java 中的一个特殊类,它可以让每个线程拥有自己独立的变量副本,避免了多线程之间的共享变量问题。下面我们将详细介绍 Java 中 ThreadLocal 的正确用法。 用法一...
总结来说,Java中的临界区通过`synchronized`关键字或Lock对象来保证多线程环境下的数据一致性,而ThreadLocal则通过为每个线程提供变量的独立副本,避免了共享资源的并发问题。在实际编程中,开发者需要根据具体...
Java ThreadLocal使用案例详解 Java ThreadLocal是Java语言中的一种机制,用于为每个线程提供一个独立的变量副本,以解决多线程环境下共享变量的线程安全问题。在本文中,我们将详细介绍Java ThreadLocal的使用案例...
ThreadLocal并不是用来替代传统的同步机制(如synchronized关键字)的,而是提供了一种不同的并发控制策略。 ThreadLocal类的核心在于它的`set`、`get`和`remove`方法。`set`方法用于设置当前线程的ThreadLocal变量...
总的来说,ThreadLocal是Java并发编程中的一种实用工具,它可以避免使用同步机制(如`synchronized`关键字)来保证线程安全,简化了多线程环境下的编程模型。然而,需要注意的是,如果不再使用ThreadLocal变量,应...
ThreadLocal通常被用来解决线程共享数据时可能出现的并发问题,避免了使用synchronized关键字进行同步控制的复杂性。 在Java中,ThreadLocal的工作原理是为每个线程创建一个单独的存储空间,每个线程可以独立地读写...
Java并发编程中的ThreadLocal类是一个非常重要的工具,它允许我们在多线程环境下为每个线程维护独立的变量副本,从而避免了线程间的数据共享和同步问题。ThreadLocal并不是一个线程,而是一个线程局部变量的容器。...
**ThreadLocal** 是 Java 中处理多线程资源共享问题的有效机制之一。它通过为每个线程提供独立的变量副本来避免线程间的资源竞争,从而简化了多线程编程的复杂度。理解 ThreadLocal 的工作原理和应用场景对于编写...
与传统的同步机制(如`synchronized`关键字或`java.util.concurrent`包中的工具)相比,ThreadLocal的优势在于它不需要显式的锁来控制对共享变量的访问。每个线程都有自己的变量副本,因此在多线程环境中,它们不会...
需要重点强调的的是,不要拿ThreadLocal和synchronized做类比,因为这种比较压根是无意义的!sysnchronized是一种互斥同步机制,是为了保证在多线程环境下对于共享资源的正确访问。而ThreadLocal从本质上讲,无非...
总结来说,ThreadLocal和`synchronized`都是Java中处理线程安全问题的策略。ThreadLocal通过为每个线程提供独立的变量副本,实现了线程隔离,减少了同步的需要,提高了效率。而`synchronized`则是通过强制线程串行...
ThreadLocal 是 Java 语言中的一种多线程编程机制,用于解决多线程程序的并发问题。它不是一个 Thread,而是一个 Thread 的局部变量。ThreadLocal 的出现是为了解决多线程程序中的共享变量问题。当多个线程访问同一...
在Java中,有多种方式可以实现线程间的数据共享和对象独立,其中ThreadLocal是常用的工具之一。 在多线程环境下,共享数据通常会引发线程安全问题,比如上述例子中的“张三给李四转钱”场景,如果两个线程同时操作...
### ThreadLocal详解:Java多线程中的线程局部变量 #### 重要概念解析:ThreadLocal在Java多线程中的角色 ...理解并掌握ThreadLocal的工作原理和使用技巧,对于Java开发者而言,是提高多线程编程水平的关键步骤之一。
2. **简化同步管理**:使用ThreadLocal,开发者无需担心同步问题,因为每个线程只操作自己的副本,减少了对synchronized关键字的依赖,降低了并发编程的复杂性。 3. **事务一致性**:在需要在一个事务中执行多个操作...