1.11守护线程

在Java中有两种线程,一种为用户线程,一种为守护线程。

守护线程是一种特殊的线程,它具有“陪伴”的含义,当进程中不存在非守护线程时,则守护线程自动销毁。

典型的守护线程就是垃圾回收线程。

当进程中没有线程了,则垃圾回收线程也就没有存在的必要了,自动销毁。

任何一个守护线程,都是JVM中所有的非守护线程的保姆,只要当前JVM实例中存在任何一个非守护线程,且没有结束,守护线程就在工作,只有当最后一个非守护线程结束时,守护线程才随着JVM一同结束工作。

Daemon的作用就是为其他线程运行提供便利,守护线程最典型的应用就是GC。

线程代码:

public class Thread1 extends Thread {
    private int i = 0;

    @Override
    public void run() {
        try {
            while (true) {
                i++;
                System.out.println("i = " + i);
                Thread.sleep(1000);
            }
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

执行代码:

public class Main {
    public static void main(String[] args) {
        try {
            Thread1 thread = new Thread1();
            thread.setDaemon(true);
            thread.start();
            Thread.sleep(5000);
            System.out.println("main线程停止了,则守护线程也停止了。不在打印。");
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

执行结果:

随着主线程停止了工作,守护线程随即也停止了工作。

源码地址:https://github.com/lilinzhiyu/threadLearning

本文内容是书中内容兼具自己的个人看法所成。可能在个人看法上会有诸多问题(毕竟知识量有限,导致认知也有限),如果读者觉得有问题请大胆提出,我们可以相互交流、相互学习,欢迎你们的到来,心成意足,等待您的评价。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java编程技术

使用数据库悲观锁实现不可重入的分布式锁

在同一个jvm进程中时,可以使用JUC提供的一些锁来解决多个线程竞争同一个共享资源时候的线程安全问题,但是当多个不同机器上的不同jvm进程共同竞争同一个共享资源...

561
来自专栏数据之美

Java 多线程之 Runnable VS Thread 及其资源共享问题

对于 Java 多线程编程中的 implements Runnable 与 extends Thread,部分同学可能会比较疑惑,它们之间究竟有啥区别和联系呢?...

1896
来自专栏Jed的技术阶梯

Kafka 自定义分区器

(1) 如果键值为 null,并且使用了默认的分区器,那么记录将被随机地发送到主题内各个可用的分区上。分区器使用轮询(Round Robin)算法将消息均衡地分...

1002
来自专栏玩转全栈

Flutter中利用MapCache加sqflite实现一个伪LRU三级缓存

在做flutter应用的时候,遇到了一个问题,纯粹属于自己给自己加戏,问题是什么呢?我的app首页是一个列表,目前每次进应用,都是通过网络拿到新的列表,所以,如...

843
来自专栏Jimoer

线程池ThreadPoolExecutor的一种扩展办法

概述 ---- 在JAVA的世界里,如果想并行的执行一些任务,可以使用ThreadPoolExecutor。  大部分情况下直接使用ThreadPoolExec...

3347
来自专栏我的小碗汤

服务接口的流量控制策略之RateLimit

很多做服务接口的人或多或少的遇到这样的场景,由于业务应用系统的负载能力有限,为了防止非预期的请求对系统压力过大而拖垮业务应用系统。

271
来自专栏有刻

Java 小记 — RabbitMQ 的实践与思考

34410
来自专栏Java开发者杂谈

线程间通信

  如果一个多线程程序中每个线程处理的资源没有交集,没有依赖关系那么这是一个完美的处理状态。你不用去考虑临界区域(critical section),不用担心存...

3439
来自专栏项勇

笔记 34 | java线程之Thread线程优先

1575
来自专栏Java编程

Java多线程Thread VS Runnable详解

进程是程序在处理机中的一次运行。一个进程既包括其所要执行的指令,也包括了执行指令所需的系统资源,不同进程所占用的系统资源相对独立。所以进程是重量级的任务,它们之...

2910

扫码关注云+社区