首页 > 代码库 > ThreadLocal实现:java线程范围内的共享数据,线程外独立
ThreadLocal实现:java线程范围内的共享数据,线程外独立
场景应用:银行转账时,A给B转账,C给D转账。两者都是调用的connection.begainTransaction();connection.commit();
如何才能保证A,B同在一个线程中,C、D同在一个线程中,且A,BC,D在线程内共享,在线程外独立。
方法一,Map<Thread, Integer>实现:
/** * 线程范围内的共享数据 */ package cn.itcast.lesson5; import java.util.HashMap; import java.util.Map; import java.util.Random; public class TestThreadLocal { private static int data = http://www.mamicode.com/0;>方法二,ThreadLocal实现:
package cn.itcast.lesson5; import java.util.Random; public class ThreadLocal11 { private static ThreadLocal<Integer> x = new ThreadLocal<Integer>(); public static void main(String[] args){ //产生两个线程数据 for(int i=0;i<2;i++){ new Thread(new Runnable() { public void run() { int data = http://www.mamicode.com/new Random().nextInt();>[注:A,B同在Thread-0下线程,C、D(另一A,B)同在Thread-1下线程。相互之间不影响。一个ThreadLocal代表一个变量,故其中只能放一个数据,你有两个变量都要线程范围内共享,则要定义两个ThreadLocal对象,如果有一百个变量要线程共享呢?那请先定义一个对象来封装这个变量,然后再ThreadLocal中存储这个对象。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。