博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ThreadLocal--线程独自共享变量
阅读量:4041 次
发布时间:2019-05-24

本文共 1316 字,大约阅读时间需要 4 分钟。

变量值的共享可以使用public static变量的形式,所有的线程都使用同一个public static变量。如果想实现每一个线程都有自己的共享变量需要用到类ThreadLocal。

package wusc.edu.concurrent.comondemo;public class MyThreadLocal {	public static ThreadLocal
t = new ThreadLocal
(); public static void main(String args[]){ Thread a = new Thread(){ public void run(){ for(int i=0;i<10;i++){ t.set(t.get()+"--"+"tl:"+i); } System.out.println("thread a:"+t.get()); } }; Thread b = new Thread(){ public void run(){ for(int i=0;i<10;i++){ t.set(t.get()+"--"+"tl:"+i); } System.out.println("thread b:"+t.get()); } }; a.start(); b.start(); }}
输出结果如下:
thread a:null--tl:0--tl:1--tl:2--tl:3--tl:4--tl:5--tl:6--tl:7--tl:8--tl:9thread b:null--tl:0--tl:1--tl:2--tl:3--tl:4--tl:5--tl:6--tl:7--tl:8--tl:9
这里的线程A和B共用一个静态变量t,threadlocal,但是两个线程的变量数据互不干扰。实现每个线程都有自己的私有数据。无论是子线程还是父线程,数据都是隔离的。

ThreadLocal是解决线程安全问题一个很好的思路,它通过为每个线程提供一个独立的变量副本解决了变量并发访问的冲突问题。在很多情况下,ThreadLocal比直接使用synchronized同步机制解决线程安全问题更简单,更方便,且结果程序拥有更高的并发性。

进一步地,我们可以创建不同的ThreadLocal实例来实现多个变量在不同线程间的访问隔离,为什么可以这么做?因为不同的ThreadLocal对象作为不同键,当然也可以在线程的ThreadLocalMap对象中设置不同的值了。通过ThreadLocal对象,在多线程中共享一个值和多个值的区别,就像你在一个HashMap对象中存储一个键值对和多个键值对一样,仅此而已。

详细ThreadLocal原理参考以下地址

http://blog.csdn.net/lufeng20/article/details/24314381

http://blog.csdn.net/isresultxal/article/details/53319972  

你可能感兴趣的文章
Xpath使用方法
查看>>
移动端自动化测试-Mac-IOS-Appium环境搭建
查看>>
Selenium之前世今生
查看>>
Selenium-WebDriverApi接口详解
查看>>
Selenium-ActionChains Api接口详解
查看>>
Selenium-Switch与SelectApi接口详解
查看>>
Selenium-Css Selector使用方法
查看>>
Linux常用统计命令之wc
查看>>
测试必会之 Linux 三剑客之 sed
查看>>
Socket请求XML客户端程序
查看>>
Java中数字转大写货币(支持到千亿)
查看>>
Java.nio
查看>>
函数模版类模版和偏特化泛化的总结
查看>>
VMware Workstation Pro虚拟机不可用解决方法
查看>>
最简单的使用redis自带程序实现c程序远程访问redis服务
查看>>
redis学习总结-- 内部数据 字符串 链表 字典 跳跃表
查看>>
iOS 对象序列化与反序列化
查看>>
iOS 序列化与反序列化(runtime) 01
查看>>
iOS AFN 3.0版本前后区别 01
查看>>
iOS ASI和AFN有什么区别
查看>>