不要用鄙夷的眼光看待这个标题。其实「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.