這個系列,結合IDEA的Inspection和我自己的理解編寫。
抽象問題
1. 把實例造型(cast)成具體的類型
這個問題的含義是,當得到一個實例時,把它cast到一個更加具體的類型使用。這個問題存在于以下場景:
public Collection aMethod(Collection c) {
List list = (List)c;
Object o = list.get(0); // Collection中沒有get方法。導致實現者必須cast。
...
}
public void test() {
// 返回值必須cast才能使用更加具體的方法。
List alist = (List)aMethod(Arrays.asList(new String[]{"1", "2"}));
Object obj = alist.get(0);
...
}
public someMethod() {
MyInterface mi = new MyImplementation();
...
// 大部分時間調用MyInterface中的方法,但忽然發現有某個地方需要調用特定的非接口實現:
int count = ((MyImplementation)mi).specialMethod();
...
}
最后這個例子,可能是方法的實現本身的問題,比如完全可以直接使用MyImplementation來定義變量mi;也可能是抽象問題,即沒有把本來具有普遍性的方法放到接口中,而是放到了具體實現中。
public boolean equals(Object o) {
if (o == null) return false;
if (o instanceof MyClass) { // 安全檢查!
MyClass mc = (MyClass)o;
// 調用MyClass中的特定方法。
...
}
public method() {
Collection c = aMethodReturnsCollection();
List list = new ArrayList(c); //安全的類型轉換,把Collection轉換成List。
...
}
抽象問題
1. 把實例造型(cast)成具體的類型
這個問題的含義是,當得到一個實例時,把它cast到一個更加具體的類型使用。這個問題存在于以下場景:
- 出于個人原因,比如只熟悉這個具體的類型、不動腦筋的編碼。
- 需要的方法不在更抽象的類型中,只在具體類型中才有定義。
public Collection aMethod(Collection c) {
List list = (List)c;
Object o = list.get(0); // Collection中沒有get方法。導致實現者必須cast。
...
}
public void test() {
// 返回值必須cast才能使用更加具體的方法。
List alist = (List)aMethod(Arrays.asList(new String[]{"1", "2"}));
Object obj = alist.get(0);
...
}
public someMethod() {
MyInterface mi = new MyImplementation();
...
// 大部分時間調用MyInterface中的方法,但忽然發現有某個地方需要調用特定的非接口實現:
int count = ((MyImplementation)mi).specialMethod();
...
}
最后這個例子,可能是方法的實現本身的問題,比如完全可以直接使用MyImplementation來定義變量mi;也可能是抽象問題,即沒有把本來具有普遍性的方法放到接口中,而是放到了具體實現中。
- 受環境約束,必須安全的使用造型。
public boolean equals(Object o) {
if (o == null) return false;
if (o instanceof MyClass) { // 安全檢查!
MyClass mc = (MyClass)o;
// 調用MyClass中的特定方法。
...
}
public method() {
Collection c = aMethodReturnsCollection();
List list = new ArrayList(c); //安全的類型轉換,把Collection轉換成List。
...
}