java虛擬機鉤子關閉函數addShutdownHook的操作
當jvm虛擬機被關閉的時候,可能我們需要做一些處理,比如對連接的關閉,或者對一些必要信息的存儲等等操作,這里就可以借助于虛擬機提供的鉤子函數,當jvm虛擬機關閉之前會去調用addShutdownHook注冊的線程鉤子。
這里做一個小實驗,項目結構如下:

1.自定義的ApplicationContext的上下文
package cn.lijie;
public class ApplicationContext {
private static ApplicationContext application;
private void init() {
application = this;
Runtime.getRuntime().addShutdownHook(new MyShutdownHook());
}
public void close() {
System.out.println("鉤子函數關閉連接操作");
}
public static ApplicationContext getApplication() {
return application;
}
}
2.定義一個鉤子線程MyShutdownHook
package cn.lijie;
public class MyShutdownHook extends Thread {
public void run() {
System.out.println("鉤子函數調用,準備關閉連接");
ApplicationContext.getApplication().close();
System.out.println("鉤子函數調用,連接已經關閉");
}
}
3.spring容器的啟動main
package cn.lijie;
public class ApplicationContext {
private static ApplicationContext application;
private void init() {
application = this;
Runtime.getRuntime().addShutdownHook(new MyShutdownHook());
}
public void close() {
System.out.println("鉤子函數關閉連接操作");
}
public static ApplicationContext getApplication() {
return application;
}
}
4.application.xml
<bean name="application" class="cn.lijie.ApplicationContext" init-method="init" />
當執(zhí)行main方法的時候創(chuàng)建spring容器,然后關閉,屆時就會執(zhí)行之前注冊的鉤子線程。
打印結果如下:

補充:JAVA虛擬機關閉鉤子(Shutdown Hook)、finally(try,catch)、finalize()調用場景及執(zhí)行順序
JAVA虛擬機關閉鉤子(Shutdown Hook)、finally(try,catch)、finalize(),三者都能在虛擬機關閉前做一些操作,但是調用場景和執(zhí)行順序不一樣。
1. JAVA虛擬機關閉鉤子(Shutdown Hook)在下面場景下被調用:
1) 程序正常退出;
2) 使用System.exit();
3) 終端使用Ctrl+C觸發(fā)的中斷;
4)系統關閉;
5)OutOfMemory宕機;
6) 使用Kill pid命令干掉進程(注:在使用kill -9 pid時,是不會被調用的);
2. finally(try...catch..)
當try里面的代碼引起的錯誤導致虛擬機關閉前,執(zhí)行finally;
3.finalize()方法
虛擬機垃圾回收過程中執(zhí)行的方法;
4.三個方法的執(zhí)行順序
1) 從java的API文檔介紹可得Shutdown Hook會在finalize()之前執(zhí)行:

2)寫了一個測試類測試finally和Shutdown Hook的執(zhí)行順序,可以看出finally在Shutdown Hook之前執(zhí)行:
package Test;
public class ShutDownHookTest {
public static void main(String[] args) {
try {
new ShutDownHookTest().addShutdownHook();
String strs= "hello";
strs.charAt(8);
}catch(Exception e) {
e.printStackTrace();
}finally {
System.out.println("執(zhí)行了finally!");
}
}
public void addShutdownHook() {
Runtime.getRuntime().addShutdownHook(new Thread() {
public void run() {
try {
System.out.println("執(zhí)行了ShutdownHook!");
} catch (Throwable t) {
t.printStackTrace();
}
}
});
}
}
3)這三個方法的執(zhí)行順序:finally-》Shutdown Hook-》finalize()
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
- Java虛擬機之類加載
- java虛擬機之JVM調優(yōu)詳解
- Java虛擬機內存區(qū)域劃分詳解
- 概述java虛擬機中類的加載器及類加載過程
- 深入了解Java虛擬機棧以及內存模型
- 淺析Java虛擬機詳解之概述、對象生存法則
- Java跨平臺原理與虛擬機相關簡介
- java虛擬機jvm方法區(qū)實例講解
- java虛擬機是做什么用的
- 詳解Java 虛擬機垃圾收集機制
- Java虛擬機使用jvisualvm工具遠程監(jiān)控tomcat內存
- Java虛擬機常見內存溢出錯誤匯總
- Java虛擬機執(zhí)行引擎知識總結
- Java啟用Azure Linux虛擬機診斷設置
- Java虛擬機內存溢出與內存泄漏
- java虛擬機創(chuàng)建失敗的原因整理
- Java內存模型中的虛擬機棧原理分析
- Java基礎之創(chuàng)建虛擬機對象的過程詳細總結
相關文章
SpringBoot+Dubbo+Zookeeper實現簡單分布式開發(fā)的應用詳解
這篇文章主要介紹了SpringBoot+Dubbo+Zookeeper實現簡單分布式開發(fā)的應用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-01-01
如何開發(fā)基于Netty的HTTP/HTTPS應用程序
HTTP/HTTPS是最常見的協議套件之一,并且隨著智能手機的成功,它的應用也日益廣泛,因為對于任何公司來說,擁有一個可以被移動設備訪問的網站幾乎是必須的。下面就來看看如何開發(fā)基于Netty的HTTP/HTTPS應用程序2021-06-06
基于Spring?Cache實現Caffeine+Redis二級緩存
本文主要介紹了基于Spring?Cache實現Caffeine+Redis二級緩存,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03

