线程范围内的共享变量,每个线程只能访问他自己的,不能访问别的线程的。
下面请看一个不安全的例子,这个例子中的data数据有安全问题,可以测试一下
import java.util.Random; public class ThreadScopeShareData { public static int data; /** * @param args */ public static void main(String[] args) { for(int i=0;i<2;i++){ new Thread(new Runnable(){ @Override public void run() { data = new Random().nextInt(); new ThreadA().getData(); new ThreadB().getData(); } }).start(); } } static class ThreadA{ public void getData(){ System.out.println("ThreadA -- " + Thread.currentThread().getName()+"-data=" + data); } } static class ThreadB{ public void getData(){ System.out.println("ThreadB -- " + Thread.currentThread().getName()+"-data=" + data); } } }
对与上述程序如何修改呢,就是实现一个类似于ThreadLocal的类一种实现,就是创建一个Map集合,键是线程自己,数据是data,取数据的时候就不会取错了。
代码如下:
import java.util.HashMap; import java.util.Map; import java.util.Random; public class ThreadScopeShareData { public static int data; public static Map<Thread,Integer> dataMap = new HashMap<Thread,Integer>(); /** * @param args */ public static void main(String[] args) { for(int i=0;i<2;i++){ new Thread(new Runnable(){ @Override public void run() { data = new Random().nextInt(); dataMap.put(Thread.currentThread(), data); new ThreadA().getData(); new ThreadB().getData(); } }).start(); } } static class ThreadA{ public void getData(){ System.out.println("ThreadA -- " + Thread.currentThread().getName()+"-data=" + dataMap.get(Thread.currentThread())); } } static class ThreadB{ public void getData(){ System.out.println("ThreadB -- " + Thread.currentThread().getName()+"-data=" + dataMap.get(Thread.currentThread())); } } }
这种实现方式类似于一些大型框架的底层实现。可以好好的看一下。