使用RunTime.getRunTime().addShutdownHook优雅关闭线程池

原文:https://blog.csdn.net/xqhadoop/article/details/62237437

通过我们的程序中运行完之后都会进行一些清理工作,比如关闭数据库资源,同步等操作。这时我们的钩子函数addShutdownHook有了用武之地。

1.钩子程序执行时机:

当程序正常退出,系统调用 System.exit方法或虚拟机被关闭时才会执行添加的shutdownHook线程。其中shutdownHook是一个已初始化但并不有启动的线程,当jvm关闭的时候,会执行系统中已经设置的所有通过方法addShutdownHook添加的钩子,当系统执行完这些钩子后,jvm才会关闭。所以可通过这些钩子在jvm关闭的时候进行内存清理、资源回收等工作。 
2.用法

Runtime.getRuntime().addShutdownHook(Thread thread)

这里我们需要将一个线程对象传入,作为钩子程序的实现代码。本质上就是在jvm关闭时,执行一个线程。

3.实战

public class Client{
public void test1(){
    System.out.println("startting working......");
    Runtime.getRuntime().addShutdownHook(new Thread(){
        @Override
        public void run() {
            System.out.println("执行钩子线程");
        }
    });
    System.out.println("program endding");
}
}
执行结果:
startting working......
program endding
执行钩子线程
 

果然钩子线程是在主程序执行完毕之后才开始执行。