2004/12/31

禪說: Shit Happens!

摘錄自: http://www.csdn.net/develop/author/cxy/shithappen.shtm

Shit Happens!

不要用鄙夷的眼光看待這個標題。其實「Shit Happens」是個名言,而且還是個具有禪意的名言。 電影阿甘正傳(Forrest Gump)中,阿甘在跑步時踩到 shit,旁邊一位失意的商人問他對此事的看法,阿甘表情輕鬆地說︰「Shit Happens.」 ,這句話的意思是「人生偶而會有不順遂的事發生,沒什麼值得大驚小怪的」。這個商人于是將「SHIT HAPPENS」做成標語,結果大賣。 電影下一幕鏡頭出現一台后面貼有「SHIT HAPPENS」標語的汽車,飛來橫禍地被后面的另一台車子撞了……果真是「Shit Happens」。

「…… 這和本文章有什麼關係???」別急,繼續看下去吧﹗

Java 程式員對于例外處理機製(exception handling mechanism)應該都不陌生,因為 Java 語言強製程式員必須使用例外處理來捕捉(catch)非執行時期(non-runtime)的例外。所以你一定用過 try,catch,finally 這三個 Java 語言的關鍵詞,而且你也很有可能用過 throw 這個關鍵詞來將未處理的例外再轉出去給 call stack 的下一層 method。但是,你很有可能未曾主動 new 一個例外對象,然後將其丟出。你更有可能未曾定義過自己的例外類別。

在用 Java 設計中大型系統的時候,常常有必要定義自己的例外類別,並在適當時機主動地丟出例外。如此一來可以使得程式更穩固。

對于定義自己的例外類別,我的習慣是︰

  • 如果此例外屬于 runtime 性質,且可以補救,則此例外繼承自 java.lang.RuntimeException。
  • 如果此例外不屬于 runtime 性質,且可以補救,則此例外繼承自 java.lang.Exception。
  • 如果此例外不可以補救,則此例外繼承自 java.lang.Error。

上述這三點完全是依照 Java 語言對于例外處理的建議,相當直覺,我也就不多解釋了。除此之外,我還定義了一個我常用的例外類別,叫做 Shit,其定義如下︰

package com.skittles; 


public class Shit extends RuntimeException { 

    private String whatHappened; 

    private Shit() {} 

    public Shit(String whatHappened) { 

        this.whatHappened = whatHappened; 

   } 

   public String toString() {    

       return whatHappened; 

   } 

} 

在程式中,對于一些我認為絕對不可能會發生的情況,我會丟出 Shit,代表程式出現了絕對不應該發生的狀況。如果出現這個例外,表示程式內部有奇怪的錯誤。在測試程式時,如果 Shit Happens,我會去追查其源頭,將錯誤找出來訂正。

之所以讓 Shit 繼承自 RuntimeException,就是因為它應該不可能發生,將它定成 RuntimeException 可以使得程式不用去 catch 它。

在程式的撰寫與測試階段,Shit Happens 是免不了的。但是,在程式交給客戶或上線之后,就得確定程式正確無誤。No more shit happens.

No comments: