[Google Guava] 1.2-前置条件
生活随笔
收集整理的這篇文章主要介紹了
[Google Guava] 1.2-前置条件
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
原文鏈接?譯文鏈接?譯者:?沈義揚
前置條件:讓方法調用的前置條件判斷更簡單。
Guava在Preconditions類中提供了若干前置條件判斷的實用方法,我們強烈建議在Eclipse中靜態導入這些方法。每個方法都有三個變種:
- 沒有額外參數:拋出的異常中沒有錯誤消息;
- 有一個Object對象作為額外參數:拋出的異常使用Object.toString() 作為錯誤消息;
- 有一個String對象作為額外參數,并且有一組任意數量的附加Object對象:這個變種處理異常消息的方式有點類似printf,但考慮GWT的兼容性和效率,只支持%s指示符。例如:
| 1 | checkArgument(i >=?0,?"Argument was %s but expected nonnegative", i); |
| 2 | checkArgument(i < j,?"Expected i < j, but %s > %s", i, j); |
?
| 方法聲明(不包括額外參數) | 描述 | 檢查失敗時拋出的異常 |
| checkArgument(boolean) | 檢查boolean是否為true,用來檢查傳遞給方法的參數。 | IllegalArgumentException |
| checkNotNull(T) | 檢查value是否為null,該方法直接返回value,因此可以內嵌使用checkNotNull。 | NullPointerException |
| checkState(boolean) | 用來檢查對象的某些狀態。 | IllegalStateException |
| checkElementIndex(int index, int size) | 檢查index作為索引值對某個列表、字符串或數組是否有效。index>=0 && index<size * | IndexOutOfBoundsException |
| checkPositionIndex(int index, int size) | 檢查index作為位置值對某個列表、字符串或數組是否有效。index>=0 && index<=size * | IndexOutOfBoundsException |
| checkPositionIndexes(int start, int end, int size) | 檢查[start, end]表示的位置范圍對某個列表、字符串或數組是否有效* | IndexOutOfBoundsException |
譯者注:
*索引值常用來查找列表、字符串或數組中的元素,如List.get(int), String.charAt(int)
*位置值和位置范圍常用來截取列表、字符串或數組,如List.subList(int,int), String.substring(int)
相比Apache Commons提供的類似方法,我們把Guava中的Preconditions作為首選。Piotr Jagielski在他的博客中簡要地列舉了一些理由:
- 在靜態導入后,Guava方法非常清楚明晰。checkNotNull清楚地描述做了什么,會拋出什么異常;
- checkNotNull直接返回檢查的參數,讓你可以在構造函數中保持字段的單行賦值風格:this.field = checkNotNull(field)
- 簡單的、參數可變的printf風格異常信息。鑒于這個優點,在JDK7已經引入Objects.requireNonNull的情況下,我們仍然建議你使用checkNotNull。
在編碼時,如果某個值有多重的前置條件,我們建議你把它們放到不同的行,這樣有助于在調試時定位。此外,把每個前置條件放到不同的行,也可以幫助你編寫清晰和有用的錯誤消息。
原創文章,轉載請注明:?轉載自并發編程網 – ifeve.com本文鏈接地址:?[Google Guava] 1.2-前置條件
from:?http://ifeve.com/google-guava-preconditions/?
總結
以上是生活随笔為你收集整理的[Google Guava] 1.2-前置条件的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: [Google Guava] 10-散列
- 下一篇: [Google Guava] 9-I/O