• 线程封闭


    线程封闭

    学习材料来源于网络
    如有侵权,联系删除

    线程封闭概念

    多线程访问共享可变数据时,涉及到线程间数据同步的问题。并不是所有时候,都要用到共享数据,所以线程封闭概念就提出来了。

    数据都被封闭在各自的线程之中,就不需要同步,这种通过将数据封闭在线程中而避免使用同步的技术称为线程封闭。

    线程封闭具体的体现有:ThreadLocal、局部变量

    ThreadLocal

    ThreadLocal是Java里—种特殊的变量。

    它是一个线程级别变量,每个线程都有一个ThreadLocal就是每个线程都拥有了自己独立的一个变量,竞争条件被彻底消除了,在并发模式下是绝对安全的变量。

    用法:

    ThreadLocal<T> var = new ThreadLocal<T>();
    

    会自动在每一个线程上创建一个T的副本,副本之间彼此独立,互不影响。

    可以用ThreadLocal存储一些参数,以便在线程中多个方法中使用,用来代替方法传参的做法。

    示例:

    /** threadLocal变量,每个线程都有一个副本,互不干扰 */
    public static ThreadLocal<String> value = new ThreadLocal<>();
    /**
     * threadlocal测试
     *
     * @throws Exception
     */
    public void threadLocalTest() throws Exception {
        // threadlocal线程封闭示例
        value.set("这是主线程设置的123"); // 主线程设置值
        String v = value.get();
        System.out.println("线程1执行之前,主线程取到的值:" + v);
    
        new Thread(new Runnable() {
            @Override
            public void run() {
                String v = value.get();
                System.out.println("线程1取到的值:" + v);
                // 设置 threadLocal
                value.set("这是线程1设置的456");
    
                v = value.get();
                System.out.println("重新设置之后,线程1取到的值:" + v);
                System.out.println("线程1执行结束");
            }
        }).start();
    
        Thread.sleep(5000L); // 等待所有线程执行结束
    
        v = value.get();
        System.out.println("线程1执行之后,主线程取到的值:" + v);
    
    }
    public static void main(String[] args) throws Exception {
        new Demo7().threadLocalTest();
    }
    

    运行结果

    实在难以理解的,可以理解为,JVM维护了一个Map<Thread,T>,每个线程要用这个T的时候,用当前的线程去Map里面取。仅作为一个概念理解

    记得加油学习哦^_^
  • 相关阅读:
    【转】IDEA2019.1.3版本破解
    Docker部署Vue
    Docker使用
    MySql触发器
    JVM 理论基础目录(待更新,系列完全写完后会统一整理好)
    JVM 5 JAVA 垃圾回收机制
    JVM 运行时数据区:程序计数器、Java 虚拟机栈和本地方法栈,方法区、堆以及直接内存
    JVM 整体流程介绍
    JVM 入门指南
    Linux 常用命令(根据自己的理解随时更新)
  • 原文地址:https://www.cnblogs.com/shaoyayu/p/14073865.html
Copyright © 2020-2023  润新知