ThreadLocal

变量值得共享可以使用public static变量的形式,所有的线程都使用同一个public static变量。如果想实现每一个线程都有自己的共享变量该如何解决呢?JDK中提供的ThreadLocal正是解决这样的问题。 
ThreadLocal主要解决的就是每个线程绑定自己的值,可以将ThreadLocal类比喻成全局存放数据的盒子,盒子中可以存储每个线程的私有数据。ThreadLocal解决的是变量在不同线程键的隔离性,也就是不同 线程拥有自己的值,不同线程中的值是可以放入ThreadLocal类中进行保存的。

package org.github.lujiango;

public class Test03 {
public static ThreadLocal<Object> tl = new ThreadLocal<Object>(); static class ThreadA extends Thread {
@Override
public void run() {
try {
tl.set("ThreadA");
Thread.sleep(200);
System.out.println("ThreadA get value = " + tl.get()); } catch (Exception e) {
e.printStackTrace();
}
}
} static class ThreadB extends Thread {
@Override
public void run() {
try {
tl.set("ThreadB");
Thread.sleep(200);
System.out.println("ThreadB get value = " + tl.get()); } catch (Exception e) {
e.printStackTrace();
}
}
} public static void main(String[] args) {
try {
ThreadA a = new ThreadA();
ThreadB b = new ThreadB();
a.start();
b.start();
} catch (Exception e) {
e.printStackTrace();
}
} }

  第一次调用ThreadLocal类的get()方法返回值是null,可以自定义protected T initialValue()方法,设置默认值。

package org.github.lujiango;

class ThreadLocalExt extends ThreadLocal<String> {
@Override
protected String initialValue() {
return "defalut";
}
} public class Test03 {
public static ThreadLocalExt tl = new ThreadLocalExt(); static class ThreadA extends Thread {
@Override
public void run() {
try {
System.out.println("ThreadA get value = " + tl.get());
tl.set("ThreadA");
Thread.sleep(200);
System.out.println("ThreadA get value = " + tl.get()); } catch (Exception e) {
e.printStackTrace();
}
}
} static class ThreadB extends Thread {
@Override
public void run() {
try {
System.out.println("ThreadB get value = " + tl.get());
tl.set("ThreadB");
Thread.sleep(200);
System.out.println("ThreadB get value = " + tl.get()); } catch (Exception e) {
e.printStackTrace();
}
}
} public static void main(String[] args) {
try {
ThreadA a = new ThreadA();
ThreadB b = new ThreadB();
a.start();
b.start();
} catch (Exception e) {
e.printStackTrace();
}
} }

InheritableThreadLocal

InheritableThreadLocal可以在子线程中取得父线程继承下来的值,即可以让子线程从父进程中取得值。

package org.github.lujiango;

public class Test04 {
static InheritableThreadLocal<String> itl = new InheritableThreadLocal<String>(); static class ThreadA extends Thread {
@Override
public void run() {
try {
System.out.println("ThreadA get: " + itl.get());
} catch (Exception e) {
e.printStackTrace();
}
}
} public static void main(String[] args) { try {
itl.set("Main");
Thread.sleep(1000);
ThreadA a = new ThreadA();
a.start();
} catch (Exception e) {
e.printStackTrace();
}
} }

InheritableThreadLocal即可以设置默认值,也可以在继承父线程值的同时修改。

package org.github.lujiango;

class InheritableThreadLocalExt extends InheritableThreadLocal<String> {
@Override
protected String initialValue() {
return "defalut";
} @Override
protected String childValue(String parentValue) {
return parentValue + " child";
}
} public class Test04 {
static InheritableThreadLocalExt itl = new InheritableThreadLocalExt(); static class ThreadA extends Thread {
@Override
public void run() {
try {
Thread.sleep(1000);
System.out.println("ThreadA get: " + itl.get());
} catch (Exception e) {
e.printStackTrace();
}
}
} public static void main(String[] args) { try {
System.out.println(itl.get());
itl.set("Main1");
Thread.sleep(1000);
ThreadA a = new ThreadA();
a.start();
itl.set("Main2");
System.out.println(itl.get());
} catch (Exception e) {
e.printStackTrace();
}
} }

注:如果子线程在取得值得同时,主线程将InheritableThreadLocal中的值进行更改,那么子线程取到的值还是旧值。

多线程-ThreadLocal,InheritableThreadLocal的更多相关文章

  1. Java多线程——ThreadLocal类的原理和使用

    Java多线程——ThreadLocal类的原理和使用 摘要:本文主要学习了ThreadLocal类的原理和使用. 概述 是什么 ThreadLocal可以用来维护一个变量,提供了一个ThreadLo ...

  2. 多线程--ThreadLocal类

    一.ThreadLocal类简介--此类是在整个开发过程中至关重要的类,他主要是在开发过程中解决了核心资源和多线程并发访问的处理情况--在真正去了解ThreadLocal类作用的时候,我们可以先编写一 ...

  3. [Java多线程]-ThreadLocal源码及原理的深入分析

    ThreadLocal<T>类:以空间换时间提供一种多线程更快捷访问变量的方式.这种方式不存在竞争,所以也不存在并发的安全性问题. //-------------------------- ...

  4. Java多线程ThreadLocal介绍

    在Java多线程环境下ThreadLocal就像一家银行,每个线程就是银行里面的一个客户,每个客户独有一个保险箱来存放金钱,客户之间的金钱不影响. private static ThreadLocal ...

  5. Java多线程——ThreadLocal类

    一.概述   ThreadLocal是什么呢?其实ThreadLocal并非是一个线程的本地实现版本,它并不是一个Thread,而是threadlocalvariable(线程局部变量).也许把它命名 ...

  6. java并发编程(九)ThreadLocal & InheritableThreadLocal

    参考文档: https://blog.csdn.net/u012834750/article/details/71646700 threadlocal内存泄漏:http://www.importnew ...

  7. Java 多线程--ThreadLocal Timer ExecutorService

    ThreadLocal /** * ThreadLocal:每个线程自身的存储本地.局部区域 * @author xzlf * */ public class ThreadLocalTest01 { ...

  8. 深入理解Java多线程——ThreadLocal

    目录 定义 API 场景分析 场景实验,观察Spring框架在多线程场景的执行情况 10000此请求,单线程 10000次请求,线程数加到100 对c的访问加锁 把c设为ThreadLocal 收集多 ...

  9. 一步一步学多线程-ThreadLocal源码解析

    上网查看了很多篇ThreadLocal的原理的博客,上来都是文字一大堆,费劲看了半天,大脑中也没有一个模型,想着要是能够有一张图明确表示出来ThreadLocal的设计该多好,所以就自己看了源码,画了 ...

随机推荐

  1. linux安装配置redis

    redis是支持linux的,所以linux安装redis非常简单,按照官网的提示操作即可. 下载 $ wget http://download.redis.io/releases/redis-3.2 ...

  2. FORM-加载前指定日期时间格式

    PRE-FORM -- Standard date format --BEGIN  set_application_property(DATE_FORMAT_COMPATIBILITY_MODE, ' ...

  3. jquery动态添加表单数据

    动态添加用户 实现代码 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html ...

  4. [Android Memory] Linux下malloc函数和OOM Killer

    http://www.linuxidc.com/Linux/2010-09/28364.htm Linux下malloc函数主要用来在用户空间从heap申请内存,申请成功返回指向所分配内存的指针,申请 ...

  5. linux安装ping

    https://www.cnblogs.com/iamdevops/p/5743157.html 使用docker仓库下载的ubuntu 14.04 镜像.里面精简的连 ping 命令都没有.goog ...

  6. 智普教育Python视频教程之入门基础篇,python笔记

    智普教育Python视频教程之入门基础篇,python笔记 print id()内存地址 type()变量类型 windows命令行下edit命令 python数据类型不需要指定类型 定义hostna ...

  7. python 协程的学习记录

    协程是个子程序,执行过程中,内部可中断,然后转而执行别的子程序,在适当的时候再返回来接着执行 从句法上看,协程与生成器类似,都是定义体中包含 yield 关键字的函数.可是,在协程中,yield 通常 ...

  8. 使用 session_destroy() 销毁session文件时 报 Trying to destroy uninitialized session 错误解决办法

    在使用  sessio_destroy() 销毁session文件的时候,必须要先使用session_start()   来开启session 后才能删除session文件

  9. Sqlite-Sqlite3中的数据类型

    大多数的数据库引擎(到现在据我们所知的除了sqlite的每个sql数据库引擎)都使用静态的.刚性的类型,使用静态类型,数据的类型就由它的容器决定,这个容器是这个指被存放的特定列. Sqlite使用一个 ...

  10. 云计算之路-试用Azure:每一次删除都让人如此“心惊”

    这篇博文吐槽的是Azure(Virtual Machine)的虚拟机删除功能. 在阿里云中,没有提供直接的虚拟机删除操作,如果不用某台虚拟机,“停止”即可,过期一段时间后会自动释放(这里的释放相当于删 ...