实现线程范围的共享变量

线程范围内的共享变量,每个线程只能访问他自己的,不能访问别的线程的。

下面请看一个不安全的例子,这个例子中的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())); } } }


这种实现方式类似于一些大型框架的底层实现。可以好好的看一下。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值