美文网首页
2019-06-11_Java守护进程学习笔记

2019-06-11_Java守护进程学习笔记

作者: kikop | 来源:发表于2019-06-11 07:23 被阅读0次

Java守护进程学习笔记

1.概述

Java的线程机制,在Java中有两类线程:User Thread(用户线程)、Daemon Thread(守护线程)。

Daemon的作用是为其他线程的运行提供服务,比如说GC线程。其实User Thread线程和Daemon Thread守护线程本质上来说去没啥区别的,唯一的区别之处就在虚拟机的离开时候:如果User Thread全部撤离,那么Daemon Thread也就没啥线程好服务的了,所以虚拟机也就退出了。只要当前JVM实例中尚存在任何一个非守护线程没有结束,守护线程就全部工作;只有当最后一个非守护线程结束时,守护线程随着JVM一同结束工作。守护线程最典型的应用就是 GC (垃圾回收器)。

1.1.注意点

public final void setDaemon(boolean on) ;但是有几点需要注意:

1)、thread.setDaemon(true)必须在thread.start()之前设置,否则会跑出一个IllegalThreadStateException异常。你不能把正在运行的常规线程设置为守护线程。 (备注:这点与守护进程有着明显的区别,守护进程是创建后,让进程摆脱原会话的控制+让进程摆脱原进程组的控制+让进程摆脱原控制终端的控制;所以说寄托于虚拟机的语言机制跟系统级语言有着本质上面的区别)

2)、 在Daemon线程中产生的新线程也是Daemon的。 (这一点又是与守护线程有着本质的区别了:

守护进程fork()出来的子进程不再是守护进程,尽管它把父进程的进程相关信息复制过去了,但是子进程的进程的父进程不是init进程,所谓的守护进程本质上说就是“父进程挂掉,init收养,然后文件0,1,2都是/dev/null,当前目录到/”)

3)、不是所有的应用都可以分配给Daemon线程来进行服务,比如读写操作或者计算逻辑。因为在Daemon Thread还没来的及进行操作时,虚拟机可能已经退出了。

1.2.应用场景

但是daemon Thread实际应用在那里呢?举个例子,web服务器中的Servlet,容器启动时后台初始化一个服务线程,即调度线程,负责处理http请求,然后每个请求过来调度线程从线程池中取出一个工作者线程来处理该请求,从而实现并发控制的目的。

2.实例

2.1.用户线程提前结束

没法守护了

2.1.1.代码

package com.tech.ability.resume;

import com.tech.ability.util.DateUtil;

import com.tech.ability.util.SleepUtil;

/**

  • Created by kikop on 2019/6/11.

*/

public class DaemonTest {

/**

 * 守护进程

 */

static class MyDamonRunner implements Runnable{

    @Override

    public void run() {

        try{

            System.out.println(DateUtil.getCurrentThreadInfo("begin..."));

            SleepUtil.second(10);

        } finally {

            System.out.println(DateUtil.getCurrentThreadInfo("finally run!"));

        }

    }

}

/**

 * 普通进程

 */

static class MyNormalRunner implements Runnable{

    @Override

    public void run() {

        try{

            System.out.println(DateUtil.getCurrentThreadInfo("begin..."));

            SleepUtil.second(5);

        } finally {

            System.out.println(DateUtil.getCurrentThreadInfo("finally run!"));

        }

    }

}

/**

 * main普通进程

 * @param args

 */

public static void main(String[] args) {

    Thread normalThread=new Thread(new MyNormalRunner(),"normalThread");

    normalThread.start();

    Thread daemonThread=new Thread(new MyDamonRunner(),"daemonThread");

    daemonThread.setDaemon(true);

    daemonThread.start();

}

}

2.1.2.输出结果

[2019-06-11 07:14:22] daemonThread-00012:begin...

[2019-06-11 07:14:22] normalThread-00011:begin...

[2019-06-11 07:14:27] normalThread-00011:finally run!

2.2.Daemon线程提前结束

2.2.1.代码

package com.tech.ability.resume;

import com.tech.ability.util.DateUtil;

import com.tech.ability.util.SleepUtil;

/**

  • Created by kikop on 2019/6/11.

*/

public class DaemonTest {

/**

 * 守护进程

 */

static class MyDamonRunner implements Runnable{

    @Override

    public void run() {

        try{

            System.out.println(DateUtil.getCurrentThreadInfo("begin..."));

SleepUtil.second(10); //守护线程阻塞

            File f = new File("daemon.txt");

            FileOutputStream os = new FileOutputStream(f, true);

            os.write("daemon".getBytes());

        } finally {

            System.out.println(DateUtil.getCurrentThreadInfo("finally run!"));

        }

    }

}

/**

 * 普通进程

 */

static class MyNormalRunner implements Runnable{

    @Override

    public void run() {

        try{

            System.out.println(DateUtil.getCurrentThreadInfo("begin..."));

            SleepUtil.second(15);

        } finally {

            System.out.println(DateUtil.getCurrentThreadInfo("finally run!"));

        }

    }

}

/**

 * main普通进程

 * @param args

 */

public static void main(String[] args) {

    Thread normalThread=new Thread(new MyNormalRunner(),"normalThread");

    normalThread.start();

    Thread daemonThread=new Thread(new MyDamonRunner(),"daemonThread");

    daemonThread.setDaemon(true);

    daemonThread.start();

}

}

2.2.2.输出结果

[2019-06-11 07:21:56] normalThread-00011:begin...

[2019-06-11 07:21:56] daemonThread-00012:begin...

[2019-06-11 07:22:07] daemonThread-00012:finally run!

[2019-06-11 07:22:12] normalThread-00011:finally run!

参考

1.java的守护进程与非守护进程

<u>https://blog.csdn.net/weixin_37766296/article/details/80404503</u>

相关文章

  • 2019-06-11_Java守护进程学习笔记

    Java守护进程学习笔记 1.概述 Java的线程机制,在Java中有两类线程:User Thread(用户线程)...

  • Python daemon守护进程!

    Python daemon 守护进程学习与总结。 守护进程 定义 守护进程是生存期长的一种进程。它们独立于控制终端...

  • rsync服务企业应用

    守护进程服务企业应用: 守护进程多模块功能配置 守护进程的排除功能实践 守护进程来创建备份目录 守护进程的访问控制...

  • Python多进程

    守护进程 守护进程其实就是“子进程“是否伴随主进程一起结束:守护==>伴随,即守护进程会伴随主进程的代码运行完毕后...

  • 守护进程和守护线程详解

    守护进程 什么是守护进程? 守护进程会在主进程代码运行结束的情况下,立即挂掉。 守护进程本身就是一个子进程。 主进...

  • 4.5、守护进程及信号处理实战

    1、守护进程功能的实现守护进程融入项目,解放终端。相关配置:Daemon = 1;按照守护进程的方式运行守护进程如...

  • PHP创建守护进程

    PHP 创建守护进程 执行守护进程

  • forever

    start:启动守护进程stop:停止守护进程stopall:停止所有的forever进程restart:重启守护...

  • 进程守护进程

    什么是守护进程?Linux 的大多数服务器就是用守护进程实现的,使用ps -axj可以查看守护进程: 守护进程基本...

  • redis.conf详解之daemonize

    用法 作为非守护进程运行 作为守护进程运行 注意事项: 默认情况下,Redis不作为守护进程运行。如果以守护进程运...

网友评论

      本文标题:2019-06-11_Java守护进程学习笔记

      本文链接:https://www.haomeiwen.com/subject/zpoxfctx.html