并发编程基础(三)

本文介绍了Java中的守护线程和用户线程,强调了守护线程作为后台进程的角色,以及用户线程在JVM退出时的影响。同时,详细阐述了ThreadLocal的使用,如何通过它来确保多线程环境中的变量安全,并展示了ThreadLocal设置、获取和移除的示例代码。最后,通过示例展示了ThreadLocal如何确保线程间操作的独立性,避免线程安全问题。
摘要由CSDN通过智能技术生成

并发编程基础(三)

守护线程 用户线程

守护线程:daemon 线程,实现通用功能的后台进程,非必须。例如 垃圾回收

用户线程:例如,main 方法,用户进程执行完成后守护进程自动销毁,JVM退出。

使用

设置一个线程为守护线程,需在 start() 方法线程执行之前。

 t1.setDaemon(true);

设置为守护线程后,即使没执行完成,在主线程执行完成之后,自动销毁,JVM 也会退出。

场景

可随时关闭,不会出现不良后果。一般是为用户线程服务,低优先级,垃圾回收,心跳监测,临时数据清理等。

ThreadLocal

线程本地变量。多线程操作变量的时候,操作的是本地副本,从而避免线程安全问题。

使用

get() set() 方法,设置多个值会被覆盖。

remove() 清空

   	ThreadLocal<String> threadLocal = new ThreadLocal<>();
    threadLocal.set("hello");
    threadLocal.set("work");
    System.out.println(threadLocal.get());
    threadLocal.remove();
    System.out.println(threadLocal.get());

多线程互不干扰

public class Test {
    static ThreadLocal<String> threadLocal = new ThreadLocal<>();
    public static void main(String[] args) throws InterruptedException {
      Thread t1 = new Thread(new Runnable(){
          @Override
          public void run(){
              threadLocal.set("t1");
                  try {
                      Thread.sleep(5000);
                  } catch (InterruptedException e) {
                      e.printStackTrace();
                  }
                 System.out.println(threadLocal.get());
              }
      });
        Thread t2 = new Thread(new Runnable(){
            @Override
            public void run(){
                threadLocal.set("t2");
                System.out.println(threadLocal.get());
                threadLocal.remove();
            }
        });
        t1.start();
        t2.start();
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值