并发编程基础(三)

并发编程基础(三),第1张

并发编程基础(三) 并发编程基础(三) 守护线程 用户线程

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

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

使用

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

 t1.setDaemon(true);

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

场景

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

ThreadLocal

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

使用

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

remove() 清空

   	ThreadLocal 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 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();
    }
}

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5685762.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存