首页 > 编程语言 > 详细

ThreadLocal实现:java线程范围内的共享数据,线程外独立

时间:2014-06-11 00:29:00      阅读:418      评论:0      收藏:0      [点我收藏+]

场景应用:银行转账时,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 = 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() {
				
				public void run() {
					 int data = new Random().nextInt();
					System.out.println(Thread.currentThread().getName()
							+" has put data"+data);
					//将线程的数据以key,value的形式存储
					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()
					+" get data" + data);
		}
	}
	static class B{
		public void get(){
			int data = threadData.get(Thread.currentThread());
			System.out.println("B from " + Thread.currentThread().getName()
					+" get data" + data);
		}
	}
}<span style="color:#ff0000;">
</span>

方法二,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 = new Random().nextInt();
					System.out.println(Thread.currentThread().getName()
							+" has put data"+data);
					//将线程的数据以key,value的形式存储
					x.set(data);
				new A().get();
				new B().get();
				}
			}).start();
	}
	}
	static class A{
		public void get(){
			int data =x.get();
			System.out.println("A from " + Thread.currentThread().getName()
					+" get data" + data);
		}
	}
	static class B{
		public void get(){
			int data =x.get();
			System.out.println("B from " + Thread.currentThread().getName()
					+" get data" + data);
		}
	}
}

bubuko.com,布布扣

[注:A,B同在Thread-0下线程,C、D(另一A,B)同在Thread-1下线程。相互之间不影响。一个ThreadLocal代表一个变量,故其中只能放一个数据,你有两个变量都要线程范围内共享,则要定义两个ThreadLocal对象,如果有一百个变量要线程共享呢?那请先定义一个对象来封装这个变量,然后再ThreadLocal中存储这个对象。

ThreadLocal实现:java线程范围内的共享数据,线程外独立,布布扣,bubuko.com

ThreadLocal实现:java线程范围内的共享数据,线程外独立

原文:http://blog.csdn.net/u014078192/article/details/29367849

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!