1.概述
變量值的共享能夠使用public 是static 變量的形式,全部的線程都使用同一個public static 變量。 如實現線程內的共享變量,jdk提供了ThreadLocal來解決這個問題。java
ThreadLocal主要解決就是每一個線程綁定本身的值,能夠將ThreadLocal類當作全局存放數據的盒子。bash
2.基本使用ide
基本demo演示(存取值)spa
/**
* @author 上海尚學堂 shsxt.com
* 瞭解更多 加V:java8733
*/
public class ThreadLocalDemo01 {
public static ThreadLocal t1 = new ThreadLocal();
public static void main(String[] args) {
if (t1.get() == null) {
System.out.println("從未放過值");
t1.set("存放的值");
}
System.out.println(t1.get());
System.out.println(t1.get());
}
}複製代碼
結果示例:
從未放過值
存放的值
存放的值線程
結果分析:
從第一次調用t1.get()方法時候,返會的null.而後經過set() 方法賦值後順利取出值。
類ThreadLocal解決的是變量在不一樣線程間的隔離性。也就是不一樣線程擁有本身的值。不一樣線程中的值是能夠放入ThreadLocal類中進行保存。code
3.隔離性
驗證線程變量的隔離性:cdn
package com.threadlocal;
/**
* 驗證隔離性
* @author 上海尚學堂 shsxt.com
*
*/
public class ThreadLocalDemo02 {
public static ThreadLocal demo = new ThreadLocal();
public static void main(String[] args) {
ThreadA a = new ThreadA();
a.start();
ThreadB b = new ThreadB();
b.start();
try {
for (int i = 0; i < 100; i++) {
demo.set("Main .." + (i + 1));
System.out.println("Main getValue ..." + demo.get());
Thread.sleep(200);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
class ThreadA extends Thread {
@Override
public void run() {
try {
for (int i = 0; i < 100; i++) {
ThreadLocalDemo02.demo.set("ThreadA" + (i + 1));
System.out.println("ThreadA getValue " + ThreadLocalDemo02.demo.get());
Thread.sleep(200);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
super.run();
}
}
class ThreadB extends Thread {
@Override
public void run() {
try {
for (int i = 0; i < 100; i++) {
ThreadLocalDemo02.demo.set("ThreadA" + (i + 1));
System.out.println("ThreadA getValue " + ThreadLocalDemo02.demo.get());
Thread.sleep(200);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
super.run();
}
}複製代碼
執行結果
blog
小結:
從上面執行的結果能夠看的出來,每個線程向ThreadLocal 中存值時,可是每一個線程取出的都是本身線程的值。這也就驗證的線程變量的隔離性。
上海尚學堂Java教研組原創,轉載請註明出處!感謝閱讀上海尚學堂Java技術文章。請多關注收藏!get