明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

Java FAQ(5)

[摘要]五、 面向?qū)ο笃猀5.1 extends和implements有什么不同?答:對(duì)于class而言,extends用于(單)繼承一個(gè)類(class),而implements用于實(shí)現(xiàn)一個(gè)接口(interface)。interface的引入是為了部分地提供多繼承的功能。在interface中只需聲明方...

五、 面向?qū)ο笃?br>
Q5.1  extends和implements有什么不同?
答:對(duì)于class而言,extends用于(單)繼承一個(gè)類(class),而implements用于實(shí)現(xiàn)一個(gè)接口(interface)。interface的引入是為了部分地提供多繼承的功能。在interface中只需聲明方法頭,而將方法體留給實(shí)現(xiàn)的class來做。這些實(shí)現(xiàn)的class的實(shí)例完全可以當(dāng)作interface的實(shí)例來對(duì)待。在interface之間也可以聲明為extends(多繼承)的關(guān)系。注意一個(gè)interface可以extends多個(gè)其他interface。

Q5.2  java怎么實(shí)現(xiàn)多繼承?


答:java不支持顯式的多繼承。因?yàn)樵陲@式多繼承的語言例如c++中,會(huì)出現(xiàn)子類被迫聲明祖先虛基類構(gòu)造函數(shù)的問題,而這是違反面向?qū)ο蟮姆庋b性原則的。java提供了interface和implements關(guān)鍵字來部分地實(shí)現(xiàn)多繼承。參見Q5.1。

Q5.3 abstract是什么?


答:被聲明為abstract的方法無需給出方法體,留給子類來實(shí)現(xiàn)。而如果一個(gè)類中有abstract方法,那么這個(gè)類也必須聲明為abstract。
被聲明為abstract的類無法實(shí)例化,盡管它可以定義構(gòu)造方法供子類使用。

Q5.4 public,protected,private有什么不同?


答:這些關(guān)鍵字用于聲明類和成員的可見性。public成員可以被任何類訪問,protected成員限于自己和子類訪問,private成員限于自己訪問。Java還提供了第四種的默認(rèn)可見性,一般稱為package private,當(dāng)沒有任何public,protected,private修飾符時(shí),成員是同一包內(nèi)可見。類可以用public或默認(rèn)來修飾。

Q5.5 Override和Overload有什么不同?
答:Override是指父類和子類之間方法的繼承關(guān)系,這些方法有著相同的名稱和參數(shù)類型。Overload是指同一個(gè)類中不同方法(可以在子類也可以在父類中定義)間的關(guān)系,這些方法有著相同的名稱和不同的參數(shù)類型。


Q5.6 我繼承了一個(gè)方法,但現(xiàn)在我想調(diào)用在父類中定義的方法。


答:用super.xxx()可以在子類中調(diào)用父類方法。

Q5.7 我想在子類的構(gòu)造方法中調(diào)用父類的構(gòu)造方法,該怎么辦?


答:在子類構(gòu)造方法的第一行調(diào)用super(...)即可。

Q5.8 我在同一個(gè)類中定義了好幾個(gè)構(gòu)造方法并且想在一個(gè)構(gòu)造方法中調(diào)用另一個(gè)。


答:在構(gòu)造方法第一行調(diào)用this(...)。

Q5.9 我沒有定義構(gòu)造方法會(huì)怎么樣?


答:自動(dòng)獲得一個(gè)無參數(shù)的構(gòu)造方法。

Q5.10 我調(diào)用無參數(shù)的構(gòu)造方法失敗了。


答:如果你至少定義了一個(gè)構(gòu)造方法,就不再有自動(dòng)提供的無參數(shù)的構(gòu)造方法了。你需要另外顯式定義一個(gè)無參數(shù)的構(gòu)造方法。另外一種可能是你的構(gòu)造方法或者類不是public的,參見Q5.4了解java中的可見性。

Q5.11 我該怎么定義類似于C++中的析構(gòu)方法(destructor)?


答:提供一個(gè)void finalize()方法。在Garbarge Collector回收該對(duì)象時(shí)會(huì)調(diào)用該方法。

注意實(shí)際上你很難判斷一個(gè)對(duì)象會(huì)在什么時(shí)候被回收。作者從未感到需要用到該方法。


Q5.12 我想將一個(gè)父類對(duì)象轉(zhuǎn)換成一個(gè)子類對(duì)象該怎么做?
答:強(qiáng)制類型轉(zhuǎn)換。如
public void meth(A a)
{
    B b = (B)a;
}
如果a實(shí)際上并不是B的實(shí)例,會(huì)拋出ClassCastException。所以請(qǐng)確保a確實(shí)是B的實(shí)例。


Q5.13 其實(shí)我不確定a是不是B的實(shí)例,能不能分情況處理?
答:可以使用instanceof操作符。例如
if( a instanceof B )
{
    B b = (B)a;
}
else
{
    ...
}

Q5.14 我在方法里修改了一個(gè)對(duì)象的值,但是退出方法后我發(fā)現(xiàn)這個(gè)對(duì)象的值沒變!
答:很可能你把傳入?yún)?shù)重賦了一個(gè)新對(duì)象,例如下列代碼就會(huì)造成這種錯(cuò)誤:public void fun1(A a) //a是局部參數(shù),指向了一個(gè)外在對(duì)象。
{
    a = new A(); //a指向了一個(gè)新對(duì)象,和外在對(duì)象脫鉤了。如果你要讓a作為
傳出變量,
不要寫這一句。
        a.setAttr(attr);//修改了新對(duì)象的值,外在對(duì)象沒有被修改。
}
基本類型也會(huì)出現(xiàn)這種情況。例如:
public void fun2(int a)
{
    a = 10;//只作用于本方法,外面的變量不會(huì)變化。
}





標(biāo)簽:Java FAQ(5) 

相關(guān)文章