threadlocal同步和线程同步
来源:互联网 发布:成都软件培训机构 编辑:程序博客网 时间:2024/05/22 23:19
转载自:http://www.cnblogs.com/memewry/archive/2012/08/25/2656966.html
Threadlocal和其他所有的同步机制都是为了解决多线程中的对同一变量的访问冲突,在普通的同步机制中,是通过对对象加锁来实现多个线程对同一变量的安全访问的。这时该变量是多个线程共享的,使用这种同步机制需要很细致的分析在什么时候对变量进行读写,什么时候需要锁定某个对象,什么时候释放该对象的索等等。所有这些都是因为多个线程共享了该资源造成的。Threadlocal就从另一个角度来解决多线程的并发访问,Threadlocal会为每一个线程维护一个和该线程绑定的变量副本,从而隔离了多个线程的数据共享,每一个线程都拥有自己的变量副本,从而也就没有必要对该变量进行同步了。ThreadLocal提供了线程安全的共享对象,在编写多线程代码时,可以把不安全的变量封装进ThreadLocal。
总结:当然ThreadLocal并不能替代同步机制,两者面向的问题领域不同。同步机制是为了同步多个线程对相同资源的并发访问,是为了多个线程之间进行通信的有效方式;而ThreadLocal是隔离多个线程的数据共享,从根本上就不在多个线程之间共享资源(变量),这样当然不需要对多个线程进行同步了。所以,如果你需要进行多个线程之间进行通信,则使用同步机制;如果需要隔离多个线程之间的共享冲突,可以使用ThreadLocal,这将极大地简化你的程序,使程序更加易读、简洁。
总结:线程同步处理多个线程对于相同资源的并发访问,实现通信。threadlocal为每个线程维护一个变量副本,隔离了线程的数据共享,解决共享冲突。
- threadlocal同步和线程同步
- ThreadLocal和线程同步机制的比较
- ThreadLocal和线程同步机制的比较
- threadlocal和线程同步机制的比较
- Java中的ThreadLocal和线程同步
- ThreadLocal和线程同步机制的对比
- ThreadLocal和线程同步机制的比较
- ThreadLocal和线程同步机制相比有什么优势呢
- ThreadLocal和线程同步机制相比有什么优势呢?
- 进程同步和线程同步
- 进程同步和线程同步
- 线程和线程同步
- 线程和线程同步
- 线程和线程同步
- ThreadLocal共享线程局部变量和线程同步机制的区别
- 线程化和同步
- 线程化和同步
- .net 线程和同步
- CAN总线基础知识(一)
- Java基础学习之集合框架分析和和控制台输入登录注册
- 你首先是一个人,然后你才是程序员。
- Java Thread中start和run方法的区别
- kafka相关
- threadlocal同步和线程同步
- mongodb实现lbs地理位置查找附近的商家
- GYM 100694 B.Far Manager(水~)
- 如何将自己在github写的android library开源,让大家依赖使用。。。。。。
- 微信平台开发环境nodejs+mongoDB搭建全过程
- Codeforces 534D Handshakes【贪心】
- 网页中QQ在线客服进行聊天的一些坑和解决方案
- 解决cli查看hive字段不全问题
- 类和动态内存分配,类成员的动态内存分配,new,delete,定位new