ITEM 72: 推薦使用標(biāo)準(zhǔn)異常

ITEM 72: FAVOR THE USE OF STANDARD EXCEPTIONS
??出色的程序員與經(jīng)驗(yàn)不足的程序員之間的一個(gè)區(qū)別是,專家竭盡可能的實(shí)現(xiàn)高度代碼重用尸疆。代碼重用是一件好事士聪,異常也不例外超陆。Java 庫提供了一組異常些膨,覆蓋蓋了大多數(shù) API 的大多數(shù)異常拋出需求。
??復(fù)用標(biāo)準(zhǔn)異常有幾個(gè)好處腕侄。其中最主要的一點(diǎn)是小泉,它使您的 API 更容易學(xué)習(xí)和使用,因?yàn)樗铣绦騿T已經(jīng)熟悉的既定約定冕杠。其次微姊,使用您的API的程序更容易閱讀,因?yàn)樗鼈儾粫?huì)充斥著不熟悉的異常分预。最后(也是最不重要的)兢交,更少的異常類意味著更小的內(nèi)存占用和更快的類load加載。
??最常用的異常類型是 IllegalArgumentException (item 49)笼痹。通常是在傳遞了不合適的參數(shù)時(shí)拋出的異常配喳。例如,如果調(diào)用者在參數(shù)中傳遞了一個(gè)負(fù)數(shù)凳干,表示某個(gè)操作將要重復(fù)的次數(shù)晴裹,此時(shí)拋出 IllegalArgumentException 就是合適的。
??另一個(gè)常用的重用異常是 IllegalStateException纺座。如果接收對(duì)象的狀態(tài)導(dǎo)致調(diào)用不合法息拜,則通常會(huì)拋出此異常溉潭。如果調(diào)用者在正確初始化某個(gè)對(duì)象之前就試圖使用該對(duì)象净响,則會(huì)拋出此異常少欺。
??可以論證的是,每個(gè)錯(cuò)誤的方法調(diào)用都?xì)w結(jié)為非法的參數(shù)或狀態(tài)馋贤,但是其他例外通常用于某些類型的非法參數(shù)和狀態(tài)赞别。如果調(diào)用者在某些禁止 null 值的參數(shù)中傳遞 null,則此時(shí)約定應(yīng)當(dāng)拋出NullPointerException配乓,而不是 IllegalArgumentException仿滔。同樣,如果調(diào)用者在表示索引的參數(shù)中傳遞一個(gè)超出范圍的值到序列中犹芹,則應(yīng)該拋出 IndexOutOfBoundsException崎页,而不是拋出 IllegalArgumentException。
??另一個(gè)可重用異常是 ConcurrentModificationException腰埂。如果為單個(gè)線程(或具有外部同步)使用而設(shè)計(jì)的對(duì)象檢測到正在并發(fā)地修改它飒焦,則應(yīng)該拋出它。這個(gè)異常充其量只是一個(gè)提示屿笼,因?yàn)椴豢赡芸煽康貦z測并發(fā)修改牺荠。
??最后一個(gè)需要注意的標(biāo)準(zhǔn)異常是 UnsupportedOperationException。這是在對(duì)象不支持嘗試的操作時(shí)拋出的異常驴一。它的使用很少休雌,因?yàn)榇蠖鄶?shù)對(duì)象都支持它們的所有方法。如果類無法實(shí)現(xiàn)由其實(shí)現(xiàn)的接口定義的一個(gè)或多個(gè)可選操作肝断,則使用此異常杈曲。例如,如果有人試圖從列表中刪除元素胸懈,僅添加的列表實(shí)現(xiàn)將拋出此異常鱼蝉。
??不要直接在你的代碼中使用 Exception, RuntimeException, Throwable, 或 Error。將這些類視為抽象類箫荡。您無法可靠地測試這些異常魁亦,因?yàn)樗鼈兪欠椒赡軖伋龅钠渌惓5某悺?br> ??雖然這些是目前為止最常見的重用異常,但在環(huán)境允許的情況下可以重用其他異常羔挡。例如洁奈,如果您正在實(shí)現(xiàn)諸如復(fù)數(shù)或有理數(shù)等算術(shù)對(duì)象,那么重用 ArithmeticException 和NumberFormatException 將是合適的绞灼。如果一個(gè)異常符合您的需要利术,那么就繼續(xù)使用它,但前提是拋出它的條件必須與異常的文檔一致:重用必須基于文檔化的語義低矮,而不僅僅是名稱印叁。另外,如果你想添加更多的細(xì)節(jié),可以隨意地子類化一個(gè)標(biāo)準(zhǔn)異常(item 75)轮蜕,但是記住異常是可序列化的(item 12)昨悼。這就是沒有充分理由不編寫自己的異常類的原因。
??選擇重用哪個(gè)異吃韭澹可能很棘手率触,因?yàn)樯媳碇械摹笆褂脠龊稀彼坪醪⒉换コ狻汇竭?紤]表示一副牌的對(duì)象的情況葱蝗,并假設(shè)有一種方法以牌的大小作為參數(shù)來處理這副牌中的一手牌。如果調(diào)用者傳遞的值大于牌堆中剩余的牌的數(shù)量细燎,它可以被解釋為一個(gè)IllegalArgumentException (handSize參數(shù)值太高) 或一個(gè) IllegalStateException (牌堆包含的牌太少)两曼。在這些情況下,如果沒有參數(shù)值可以工作玻驻,規(guī)則是拋出 IllegalStateException合愈,否則拋出IllegalArgumentException。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末击狮,一起剝皮案震驚了整個(gè)濱河市佛析,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌彪蓬,老刑警劉巖寸莫,帶你破解...
    沈念sama閱讀 219,270評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異档冬,居然都是意外死亡膘茎,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門酷誓,熙熙樓的掌柜王于貴愁眉苦臉地迎上來披坏,“玉大人,你說我怎么就攤上這事盐数“舴鳎” “怎么了?”我有些...
    開封第一講書人閱讀 165,630評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵玫氢,是天一觀的道長帚屉。 經(jīng)常有香客問我,道長漾峡,這世上最難降的妖魔是什么攻旦? 我笑而不...
    開封第一講書人閱讀 58,906評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮生逸,結(jié)果婚禮上牢屋,老公的妹妹穿的比我還像新娘且预。我一直安慰自己,他們只是感情好烙无,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,928評(píng)論 6 392
  • 文/花漫 我一把揭開白布锋谐。 她就那樣靜靜地躺著,像睡著了一般皱炉。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上狮鸭,一...
    開封第一講書人閱讀 51,718評(píng)論 1 305
  • 那天合搅,我揣著相機(jī)與錄音,去河邊找鬼歧蕉。 笑死灾部,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的惯退。 我是一名探鬼主播赌髓,決...
    沈念sama閱讀 40,442評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼催跪!你這毒婦竟也來了锁蠕?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,345評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤懊蒸,失蹤者是張志新(化名)和其女友劉穎荣倾,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體骑丸,經(jīng)...
    沈念sama閱讀 45,802評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡舌仍,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,984評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了通危。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片铸豁。...
    茶點(diǎn)故事閱讀 40,117評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖菊碟,靈堂內(nèi)的尸體忽然破棺而出节芥,到底是詐尸還是另有隱情,我是刑警寧澤逆害,帶...
    沈念sama閱讀 35,810評(píng)論 5 346
  • 正文 年R本政府宣布藏古,位于F島的核電站,受9級(jí)特大地震影響忍燥,放射性物質(zhì)發(fā)生泄漏拧晕。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,462評(píng)論 3 331
  • 文/蒙蒙 一梅垄、第九天 我趴在偏房一處隱蔽的房頂上張望厂捞。 院中可真熱鬧输玷,春花似錦、人聲如沸靡馁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,011評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽臭墨。三九已至赔嚎,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間胧弛,已是汗流浹背尤误。 一陣腳步聲響...
    開封第一講書人閱讀 33,139評(píng)論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留结缚,地道東北人损晤。 一個(gè)月前我還...
    沈念sama閱讀 48,377評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像红竭,于是被迫代替她去往敵國和親尤勋。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,060評(píng)論 2 355