爲您的Java應用程序添加退出事件處理

一個完整的Java應用程序,通常至少要有一個應用程序的結束點。對於一般程序來說,系統開發者根據需要和個人的偏好,會在程序結束位置,通過添加System.exit(0),或System.out(-1),來結束程序,或不加這些指令,讓程序自然運行到結束。

如:下列典型代碼

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);//也可以不寫這句代碼,讓程序自然結束。
    
  }
}

對於簡單的應用系統,我們直接可以在System.exit(0)代碼執行前,添加需要在應用程序退出前需要完成的工作,如:關閉網絡連接,關閉數據庫連接等。

然而,對於比較複雜的多線程應用,線程運行的狀態較複雜,我們就很難預料程序何時結束,如何能在應用程序結束事件到來時,處理我們要做的工作呢?這就用到了Java對應用程序的退出的事件出處理機制。

對當前應用程序對象的獲得,Java通過Runtime靜態方法:Runtime.getRuntime()通過Runtime的 void addShutdownHook(Thread hook) 法向Java虛擬機註冊一個shutdown鉤子事件,這樣一旦程序結束事件到來時,就運行線程hook,我們在實際應用時候,只要將程序需要完成之前做的一些工作直接通過線程hook來完成。具體演示代碼如下:

/*****************************************************************************
本程序僅演示,如何在Java應用程序中添加系統退出事件處理機制
*****************************************************************************/
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
   * 這裏爲了演示,爲應用程序的退出增加了一個事件處理,
   * 當應用程序退出時候,將程序退出的日期寫入 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("I'm going to end");
          fw.write("the application ended! " + (new Date()).toString());
          fw.close();
        }
        catch (IOException ex) {
        }

      }
    });
  }
  /****************************************************
   * 這是程序的入口,僅爲演示,方法中的代碼無關緊要
   ***************************************************/
  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()) 事件監聽,捕獲系統退出消息到來,然後,執行我們所需要完成工作,從而使我們的程序更健壯!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章