并发编程基础(三)

 2023-09-11 阅读 13 评论 0

摘要:并发编程基础(三) 守护线程 用户线程 守护线程:daemon 线程,实现通用功能的后台进程,非必须。例如 垃圾回收 用户线程:例如,main 方法,用户进程执行完成后守护进程自动销毁,JVM退出。 使用 设置一个线程为守护

并发编程基础(三)

守护线程 用户线程

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

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

使用

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

 t1.setDaemon(true);

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

场景

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

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(){@Overridepublic 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(){@Overridepublic void run(){threadLocal.set("t2");System.out.println(threadLocal.get());threadLocal.remove();}});t1.start();t2.start();}
}

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/5/47168.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息