为什么要保持各个线程间的变量独立,比如connection.小王给小李转账,使用线程A,小张给小马转账使用线程B,小张跟小马的转账一切搞定后,就在刚给小李的账户加钱,还没给小王的账户减钱的时候,线程B执行connection提交,假如A和B使用的是同一个connection,那么小王的钱将没有减少,出错。
保持独立原理就是用个MAP给保存起来,然后根据不同的key去取。
代码:
import java.util.HashMap;
import java.util.Map;
import java.util.Random;
public class ThreadScopeShareData {
private static int data = 0;
private static Map<Thread,Integer> threadData = new HashMap<Thread,Integer>();
public static void main(String[] args) {
for(int i=0;i<2;++i){
new Thread(new Runnable() {
@Override
public void run() {
int data = new Random().nextInt();
System.out.println(Thread.currentThread().getName()
+" has put data : "+ data);
threadData.put(Thread.currentThread(), data);
new A().get();
new B().get();
}
}).start();
}
}
static class A{
public void get(){
int data = threadData.get(Thread.currentThread());
System.out.println(" A from "+Thread.currentThread().getName()
+" has put data : "+ data);
}
}
static class B{
public void get(){
int data = threadData.get(Thread.currentThread());
System.out.println(" B from "+Thread.currentThread().getName()
+" has put data : "+ data);
}
}
}
运行效果: