首页 > 其他分享 >线程优雅停止-两阶段终止模式

线程优雅停止-两阶段终止模式

时间:2022-09-27 14:59:14浏览次数:47  
标签:java Thread 43 优雅 DEBUG 线程 终止 ThreadTwoPhaseTermination

所谓优雅停止,即即将在停止的线程足够的时间完成善后工作,而不是直接杀死线程。假设此时某线程正在独占资源(占有锁),突然对线程的终止,会导致其占有的资源无法得到释放,其他线程将无法获取该资源。

 

package cn.yds.juc.learning;

import lombok.extern.slf4j.Slf4j;

/**
 * @author yds
 * @Date 2022/9/21 19:43
 * @Description 两阶段终模式
 * @Version 1.0.0
 */
public class ThreadDemo5 {
    public static void main(String[] args) throws InterruptedException {
        ThreadTwoPhaseTermination phaseTermination = new ThreadTwoPhaseTermination();
        phaseTermination.start();
        Thread.sleep(10000);
        phaseTermination.stop();
    }
}


@Slf4j(topic = "ThreadTwoPhaseTermination")
class ThreadTwoPhaseTermination{

    private Thread monitor;

    /**
     * 开启监控线程
     */
    public void start(){
        monitor = new Thread(()->{
            while (true){
                Thread thread = Thread.currentThread();
                if (thread.isInterrupted()){
                    log.debug("料理后事");
                    break;
                }
                try {
                    Thread.sleep(2000);//情况一:此处被打断,打断标记会被清空(false).所以要在catch中重新设置
                    log.debug("执行监控记录");//情况二:此处被打断,打断标记是true,下次循环就退出了
                } catch (InterruptedException e) {
                    e.printStackTrace();
                    //重置打断标记为true
                    thread.interrupt();
                }
            }
        });
        monitor.start();
    }


    /**
     * 停止监控线程
     */
    public void stop(){
        monitor.interrupt();
    }

}

演示:

 

14:43:02.841 [Thread-0] DEBUG ThreadTwoPhaseTermination - 执行监控记录
14:43:04.848 [Thread-0] DEBUG ThreadTwoPhaseTermination - 执行监控记录
14:43:06.851 [Thread-0] DEBUG ThreadTwoPhaseTermination - 执行监控记录
14:43:08.853 [Thread-0] DEBUG ThreadTwoPhaseTermination - 执行监控记录
java.lang.InterruptedException: sleep interrupted
    at java.lang.Thread.sleep(Native Method)
    at cn.yds.juc.learning.ThreadTwoPhaseTermination.lambda$start$0(ThreadDemo5.java:38)
    at java.lang.Thread.run(Thread.java:748)
14:43:10.840 [Thread-0] DEBUG ThreadTwoPhaseTermination - 料理后事 开始 

标签:java,Thread,43,优雅,DEBUG,线程,终止,ThreadTwoPhaseTermination
From: https://www.cnblogs.com/ieas/p/16734532.html

相关文章

  • 通过Thread Pool Executor类解析线程池执行任务的核心流程
    摘要:ThreadPoolExecutor是Java线程池中最核心的类之一,它能够保证线程池按照正常的业务逻辑执行任务,并通过原子方式更新线程池每个阶段的状态。本文分享自华为云社区《【高......
  • 多线程环境下安全的集合
    多线程环境下安全的集合List/***并发修改异常多个线程同时操作一个不安全的集合*<p>*CopyOnWriteArrayList写时复制技术*add方法会先复制一个新数组对新......
  • 线程打断(interrupt)状态演示
    packagecn.yds.juc.learning;importlombok.extern.slf4j.Slf4j;/***@authoryds*@Date2022/9/2119:25*@DescriptionThreadDemo4*@Version1.0.0*/......
  • 线程池底层原理详解与源码分析
    【1】为什么要使用线程池?示例演示://设置业务模拟classMyRunnableimplementsRunnable{privateintcount;publicMyRunnable(intcount){......
  • wait sleep 线程切换 IO阻塞 轮询 锁是否释放和当前线程是否占用CPU资源问题
    1wait以后的notify()函数释放锁,不占用CPU资源,线程暂定,CPU资源被让出。 2sleep()函数不释放锁,但是让出CPU资源,确定唤醒时间。 3yield()函数和操作系统的自发......
  • 开源动态可监控线程池DynamicTp介绍
    前言使用线程池ThreadPoolExecutor过程中你是否有以下痛点呢?代码中创建了一个ThreadPoolExecutor,但是不知道那几个核心参数设置多少比较合适凭经验设置参数值,上......
  • Java SE 19 虚拟线程
    JavaSE19虚拟线程作者:Grey原文地址:博客园:JavaSE19虚拟线程CSDN:JavaSE19虚拟线程说明虚拟线程(VirtualThreads)是在ProjectLoom中开发的,并从JavaSE19开......
  • 虚拟线程
    Java19新特性:虚拟线程(VirtualThreads)......
  • C++多线程编程之【线程管理】
    1.如何启动线程?构建std::thread对象即可。直接传函数名(地址)创建一个类并创建伪函数。构建对象(实例化),将对象作为参数传入thread对象实例化。2.为什么要等待线程?首先......
  • 多线程
    1.线程和进程区别线程的划分尺度小于进程,这使多线程程序拥有高并发性,进程在运行时各内存单元之间相互独立,线程之间内存共享,这使多线程拥有更好的性能和用户体验。线程......