在对多个线程进行 *** 作时,出于安全的考虑,我们会在其中加入锁的时候。除了这种方法外,我们还可以通过ThreadLocal来定义变量,使线程对应固定变量减少出错的可能性。下面我们就ThreadLocal的概念、使用场景,以及在一个框架中创建的实例,为大家带来全面的讲解。
1.概念
是JDK包提供的,它提供线程本地变量,如果创建ThreadLocal变量,那么访问这个变量的每个线程都会有这个变量的一个副本,在实际多线程 *** 作的时候, *** 作的是自己本地内存中的变量,从而规避了线程安全问题。
2.使用场景
(1)在进行对象跨层传递的时候,使用ThreadLocal可以避免多次传递,打破层次间的约束。
(2)线程间数据隔离
(3)进行事务 *** 作,用于存储线程事务信息。
(4)数据库连接,Session会话管理。
3.实例
Spring框架里用的ThreadLocal来实现隔离。 public abstract class TransactionSynchronizationManager { //线程绑定的资源,比如DataSourceTransactionManager绑定是的某个数据源的一个Connection,在整个事务执行过程中 //都使用同一个Jdbc Connection private static final ThreadLocal
以上就是java中ThreadLocal的使用介绍,相信大家已经学会用它来处理一个线程的问题。当想要保证线程安全性时,除了锁的方法,还可以考虑使用ThreadLocal来降低风险。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)