线程范围ThreadLocal

线程范围内的共享变量,通俗的说就是指:特定的线程对应特定的数据,不会因为对象的变化数据而改变。

ThreadLocal 的使用方便我们对不同的线程管理不同的数据,而且能够很好的对单例进行复用,因为我们通常不同的数据对象对应不同的单例进行保存,如果一旦分类数据过多,那么我们得创建大量的单例进行保存。然而ThreaLocal能够做到单例的复用。下面请看代码

public class ThreadScopShareData {

	 static ThreadLocal<Integer> x= new ThreadLocal<Integer>();

//	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() {
					// TODO Auto-generated method stub
					int  data = new Random().nextInt();
					System.out.println(Thread.currentThread().getName()+"has put data: "+data);
					x.set(data);//数据存入到当前线程中
//					threadData.put(Thread.currentThread(),data);
					MyThreadScopeData.getInstance().setName("name"+data);//本线程对应的实例
					MyThreadScopeData.getInstance().setAge(data);
					new A().get();
					new B().get();
				}
			}).start();

		}

	}

	static  class A{

		public int get(){

//			int data = threadData.get(Thread.currentThread());
			int data = x.get();//获取当前线程数据
			System.out.println("A from"+Thread.currentThread().getName()+"get data: "+data);

			MyThreadScopeData mydata =  MyThreadScopeData.getInstance();

			System.out.println("A from"+Thread.currentThread().getName()+"get Mydata: "+mydata.getAge()+","+mydata.getName());
			return data;
		}
	}
     static  class B{

		public int get(){
			int data = x.get();//获取当前线程数据
//			int data = threadData.get(Thread.currentThread());
			System.out.println("B from"+Thread.currentThread().getName()+"get data: "+data);

			MyThreadScopeData mydata =  MyThreadScopeData.getInstance();

			System.out.println("B from"+Thread.currentThread().getName()+"get Mydata: "+mydata.getAge()+","+mydata.getName());
			return data;
		}
	}

}

class MyThreadScopeData{

//	private static MyThreadScopeData instance=null;

	private MyThreadScopeData(){

	}

	public static /*synchronized*/ MyThreadScopeData  getInstance(){//加同步锁是为了防止出现多个对象

		MyThreadScopeData instance = map.get();//此处可以针对不同线程new 对应的单例,提高代码的复用
		if(instance ==null){
			instance = new MyThreadScopeData();
			map.set(instance);
		}

		return instance;

	}

	private static ThreadLocal<MyThreadScopeData> map = new ThreadLocal<MyThreadScopeData>();

	private String name;
	private int age;
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public int getAge() {
		return age;
	}
	public void setAge(int age) {
		this.age = age;
	}
}

该代码的运行结果为

可见对象的不同,只要是线程一样数据就一样。

这对于我们在处理并发访问上给出了一些提示。

时间: 2024-10-18 20:44:30

线程范围ThreadLocal的相关文章

Java中线程局部变量ThreadLocal使用教程及源码分析

在Java多线程编程中有时候会遇见线程本地局部变量ThreadLocal这个类,下面就来讲讲ThreadLocal的使用及源码分析. ThreadLocal 是Thread Local Varial(线程局部变量)的意思,每个线程在使用线程局部变量的时候都会为使用这个线程局部变量的线程提供一个线程局部变量的副本,使得每个线程都可以完全独立地操作这个线程局部变量,而不会与其他线程发生冲突,从线程的角度来看,每个线程都好像独立地拥有了这个线程局部变量.这样,看似每个线程都在并发访问同一个资源(线程局

线程隔离ThreadLocal

ThreadLocal是什么 早在JDK 1.2的版本中就提供java.lang.ThreadLocal,ThreadLocal为解决多线程程序的并发问题提供了一种新的思路.使用这个工具类可以很简洁地编写出优美的多线程程序. 当使用ThreadLocal维护变量时,ThreadLocal为每个使用该变量的线程提供独立的变量副本,所以每一个线程都可以独立地改变自己的副本,而不会影响其它线程所对应的副本. 从线程的角度看,目标变量就象是线程的本地变量,这也是类名中“Local”所要表达的意思. 所以

线程变量ThreadLocal的使用

我们有时候会通过token进行多次查询(猪:token是redis中的key),比如: 一次是在登录拦截器中,一次是在controller的业务中查询,这样存在性能和资源的浪费问题!!! 那么如何将拦截器中的数据传递到Controller中呢? 有两种方案: 1,将User对象放置到request对象中 2,使用ThreadLocal线程变量实现(在进入tomcat和产生响应前,对象都处于同一个线程中) 实现: 1,定义一个ThreadLocal相关的类 public class UserThr

本地线程变量ThreadLocal (耗时工具)

本地线程变量类 package king; import java.util.ArrayList; import java.util.List; import java.util.Map; import java.util.Map.Entry; import java.util.TreeMap; /** * TLTimeContainer为ThreadLocalTimeContainer(本地线程变量时间容器)的缩写 * 说明:用来在任意一个方法内部置入recordTime(),以作片断时间点的

java并发:线程同步机制之ThreadLocal

1.简述ThreadLocal ThreadLocal实例通常作为静态的私有的(private static)字段出现在一个类中,这个类用来关联一个线程.ThreadLocal是一个线程级别的局部变量,下面是线程局部变量(ThreadLocal variables)的关键点: A.当使用ThreadLocal维护变量时,若多个线程访问ThreadLocal实例,ThreadLocal为每个使用该变量的线程提供了一个独立的变量副本,所以每一个线程都可以独立地改变自己的副本,而不会影响其他线程所对应

Spring基于ThreadLocal的“资源-事务”线程绑定设计的缘起

题目起的有些拗口了,简单说,这篇文章想要解释Spring为什么会选择使用ThreadLocal将资源和事务绑定到线程上,这背后有着什么样的起因和设计动机,通过分析帮助大家更清晰地认识Spring的线程绑定机制.本文原文链接:http://blog.csdn.net/bluishglc/article/details/7784502 转载请注明出处! “原始”的数据访问写法 访问任何带有事务特性的资源系统,像数据库,都有着相同的特点:首先你需要获得一个访问资源的“管道”,对于数据库来说,这个所谓的

深入理解线程本地变量ThreadLocal

ThreadLocal理解: 如果在多线程并发环境中,一个可变对象涉及到共享与竞争,那么该可变对象就一定会涉及到线程间同步操作,这是多线程并发问题. 否则该可变对象将作为线程私有对象,可通过ThreadLocal进行管理,实现线程间私有对象隔离的目的. 可以发现,ThreadLocal并没有解决多线程并发的问题,因为ThreadLocal管理的可变对象的性质本来就不会涉及到多线程并发而引发的共享.竞争和同步问题,使用ThreadLocal管理只是方便了多线程获取和使用该私有可变对象的途径和方式.

多线程之线程范围内的数据共享ThreadLocal

如果多个线程使用同一个数据,那么如何保证线程范围内的数据共享. 我们可以使用一个map来存储当前线程,以及其数据如下: package andy.thread.traditional.test; import java.util.HashMap; import java.util.Map; import java.util.Random; /** * @author Zhang,Tianyou * @version 2014年11月8日 下午2:12:44 */ // 线程范围内的共享数据 pu

JAVA学习篇--ThreadLocal,Java中特殊的线程绑定机制

在DRP项目中,我们使用了ThreadLocal来创建Connection连接,避免了一直以参数的形式将Connection向下传递(传递connection的目的是由于jdbc事务要求确保使用同一个connection连接).那么ThreadLocal是如果做到的呢?它和同步锁的不同在哪里? 是什么: 对于ThreadLocal看英文单词我们很容易理解为一个线程的本地实现,但是它并不是一个Thread,而是threadlocalvariable(线程局部变量).也许把它命名为ThreadLoc