ThreadLocal類的簡單使用

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

相關文章
相關標籤/搜索