2 回答

TA貢獻1846條經(jīng)驗 獲得超7個贊
僅僅因為一個類不能被實例化并不意味著你不能得到它的一個實例。
在您的示例中,您所做的只是將其轉(zhuǎn)換為 Graphics 層次結(jié)構(gòu)中的另一個類。
這是一個例子。
public class AbstractDemo {
public static void main(String[] args) {
Concrete c = new Concrete();
AClass a = (AClass) c;
a.me();
}
}
abstract class AClass {
public void me() {
System.out.println("Abstract parent");
}
}
class Concrete extends AClass {
}

TA貢獻1825條經(jīng)驗 獲得超6個贊
一個類是抽象的只是意味著你不能直接創(chuàng)建這樣一個類。一旦有了這樣的類,就可以對其進行強制轉(zhuǎn)換,使其看起來像是它的任何子類。換句話說,所有“抽象”意味著你不能做:
SomeAbstractClass obj = new SomeAbstractClass(...);
你可以引用一個Graphics2D對象,就像你的例子一樣,但是如果你要求 Java 告訴你對象的真實類型,它實際上永遠不會是一個Graphics2D對象。從這段代碼中,您不能確定所討論對象的真實類型也是一個Graphics對象。這可能再次是對真實對象的子類的引用,例如 maybeMyGraphicsObject或類似的東西。
這就是多態(tài)性的全部意義和威力。一旦你創(chuàng)建了一個對象,它的行為就像它的任何子類一樣,并且可以通過向上轉(zhuǎn)換將它視為任何這些子類的純實例。
下面是一些代碼,指出向上轉(zhuǎn)型的對象的標(biāo)識會發(fā)生什么:
abstract class Abstract {
public void whatAmI() {
System.out.println("I'm Abstract");
}
}
class Concrete extends Abstract {
@Override
public void whatAmI() {
System.out.println("I'm Concrete");
}
}
public class X {
public static void main(String[] args) {
// This won't compile. That's what it means for "Abstract" to be abstract.
// Abstract abs = new Abstract();
// You can create a Concrete, and then upcast it to an Abstract reference...
Concrete concrete = new Concrete();
Abstract abs = (Abstract)concrete;
// But it's stll really a Concrete
System.out.println(abs.getClass().getName());
// And it will still act like a Concrete if Concrete has overridden one of Abstract's methods.
abs.whatAmI();
}
}
結(jié)果:
org.littleshoot.proxy.inlet.Concrete
I'm Concrete
請注意,如果您向 Java 詢問對象的類型,即使您已經(jīng)通過抽象引用詢問了對象的類型,它仍然是具體的。另請注意,如果您在抽象類上調(diào)用已在具體中被覆蓋的方法,則將調(diào)用具體的版本。
添加回答
舉報