為Java應用程式新增退出事件響應

azz發表於2007-08-24
為Java應用程式新增退出事件響應[@more@]  一個完整的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: .log檔案
  **************************************************************************/
  private void doShutDownWork() {
  Runtime.getRuntime().addShutdownHook(new Thread() {

   public void run() {
    try {
     FileWriter fw = new FileWriter("d: .log");
     System.out.println("Im 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()) 事件監聽,捕獲系統退出訊息到來,然後,執行我們所需要完成工作,從而使我們的程式更健壯!

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10901326/viewspace-965670/,如需轉載,請註明出處,否則將追究法律責任。

相關文章