為Java應(yīng)用程序添加退出事件響應(yīng)
發(fā)表時(shí)間:2024-01-26 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]一個(gè)完整的Java應(yīng)用程序,通常至少要有一個(gè)應(yīng)用程序的結(jié)束點(diǎn)。對(duì)于一般程序來說,系統(tǒng)開發(fā)者根據(jù)需要和個(gè)人的偏好,會(huì)在程序結(jié)束位置,通過添加System.exit(0),或System.out(-1),來結(jié)束程序,或不加這些指令,讓程序自然運(yùn)行到結(jié)束。 如:下列典型代碼 package un...
一個(gè)完整的Java應(yīng)用程序,通常至少要有一個(gè)應(yīng)用程序的結(jié)束點(diǎn)。對(duì)于一般程序來說,系統(tǒng)開發(fā)者根據(jù)需要和個(gè)人的偏好,會(huì)在程序結(jié)束位置,通過添加System.exit(0),或System.out(-1),來結(jié)束程序,或不加這些指令,讓程序自然運(yùn)行到結(jié)束。
如:下列典型代碼
package untitled14;
/**
* This application is to demo how an applcation end
*/
public class Test {
public Test() {}
public static void main(String[] args) {
Test test1 = new Test();
//.................
System.out.println("hello world");
//Do something before system exit
System.exit(0);//也可以不寫這句代碼,讓程序自然結(jié)束。
}
}
對(duì)于簡(jiǎn)單的應(yīng)用系統(tǒng),我們直接可以在System.exit(0)代碼執(zhí)行前,添加需要在應(yīng)用程序退出前需要完成的工作,如:關(guān)閉網(wǎng)絡(luò)連接,關(guān)閉數(shù)據(jù)庫連接等。
然而,對(duì)于比較復(fù)雜的多線程應(yīng)用,線程運(yùn)行的狀態(tài)較復(fù)雜,我們就很難預(yù)料程序何時(shí)結(jié)束,如何能在應(yīng)用程序結(jié)束事件到來時(shí),處理我們要做的工作呢?這就用到了Java對(duì)應(yīng)用程序的退出的事件出處理機(jī)制。
對(duì)當(dāng)前應(yīng)用程序?qū)ο蟮墨@得,Java通過Runtime靜態(tài)方法:Runtime.getRuntime()通過Runtime的 void addShutdownHook(Thread hook) 法向Java虛擬機(jī)注冊(cè)一個(gè)shutdown鉤子事件,這樣一旦程序結(jié)束事件到來時(shí),就運(yùn)行線程hook,我們?cè)趯?shí)際應(yīng)用時(shí)候,只要將程序需要完成之前做的一些工作直接通過線程hook來完成。具體演示代碼如下:
/*****************************************************************************
本程序僅演示,如何在Java應(yīng)用程序中添加系統(tǒng)退出事件處理機(jī)制
*****************************************************************************/
package untitled14;
import java.util.*;
import java.io.*;
/**
* This application is used to demo how to hook the event of an application
*/
public class Untitled1 {
public Untitled1() {
doShutDownWork();
}
/***************************************************************************
* This is the right work that will do before the system shutdown
* 這里為了演示,為應(yīng)用程序的退出增加了一個(gè)事件處理,
* 當(dāng)應(yīng)用程序退出時(shí)候,將程序退出的日期寫入 d:\t.log文件
**************************************************************************/
private void doShutDownWork() {
Runtime.getRuntime().addShutdownHook(new Thread() {
public void run() {
try {
FileWriter fw = new FileWriter("d:\\t.log");
System.out.println("Im going to end");
fw.write("the application ended! " + (new Date()).toString());
fw.close();
}
catch (IOException ex) {
}
}
});
}
/****************************************************
* 這是程序的入口,僅為演示,方法中的代碼無關(guān)緊要
***************************************************/
public static void main(String[] args) {
Untitled1 untitled11 = new Untitled1();
long s = System.currentTimeMillis();
for (int i = 0; i < 1000000000; i++) {
//在這里增添您需要處理代碼
}
long se = System.currentTimeMillis();
System.out.println(se - s);
}
}
在上述程序中,我們可以看到通過在程序中增加Runtime.getRuntime().addShutdownHook(new Thread()) 事件監(jiān)聽,捕獲系統(tǒng)退出消息到來,然后,執(zhí)行我們所需要完成工作,從而使我們的程序更健壯!
<>