zoukankan      html  css  js  c++  java
  • Java守护线程

    用户线程和守护线程

    用户线程:也叫工作线程,线程的任务执行完或者通知方式结束

    守护线程:一般是位工作线程服务的,当所有的用户线程技术,守护线程自动结束,使用Thread.setDaemon(true)方法, 线程变成守护线程 。

    常见的守护线程:垃圾回收机制

    守护线程的特点: Java 中的守护线程和linux 中的守护进程还是有些区别的, linux 守护进程时系统级别的, 当系统退出时, 才会终止. 而java 中的守护线程时jvm 级别的, 当jvm中无任何用户进程时, 守护进程销毁, jvm 退出。

    实例:每个0.5秒一直输出“hello”,每隔1秒输出“hi”10次,让完成任务后的同时也结束无线循环输出“hi”的方法。

    线程部分代码

    class TestThread extends Thread {
        @Override
        public void run() {
            while(true) {
                try {
                    Thread.sleep(500);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println("hello");
            }
        }
    }
    

    主方法

    注意 :必须要先设置守护线程,才能调用t.start()方法,否则会报错

    public static void main(String[] args) throws InterruptedException {
            TestThread t = new TestThread();
            t.setDaemon(true);
            t.start();
            for (int i = 0; i < 10; i++) {
                System.out.println("hi");
                Thread.sleep(1000);
            }
        }
    
    运行结果

    image

    运行结果我们可以得到,当主线程结束后,子线程自动结束。如果希望主线程结束后,子线程可以自动结束设置成守护线程,将子线程设置位守护线程。

  • 相关阅读:
    妙味——自定义滚动条
    妙味——拖拽改变大小
    妙味——带框的拖拽
    IE6 固定定位
    JavaScript 事件绑定
    JavaScript 事件
    设置指定网页为主页
    [LeetCode][JavaScript]Compare Version Numbers
    [LeetCode][JavaScript]Implement Stack using Queues
    [LeetCode][JavaScript]Invert Binary Tree
  • 原文地址:https://www.cnblogs.com/ilyar1015/p/14707235.html
Copyright © 2011-2022 走看看