Java面試寶典2024版資料_第1頁(yè)
Java面試寶典2024版資料_第2頁(yè)
Java面試寶典2024版資料_第3頁(yè)
Java面試寶典2024版資料_第4頁(yè)
Java面試寶典2024版資料_第5頁(yè)
已閱讀5頁(yè),還剩115頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

Java面試寶典2024版

這套面試題主要目的是幫助那些還沒有java軟件開發(fā)實(shí)際工作閱歷,而正在努力找尋java軟件開發(fā)工作的孥友在筆

試時(shí)更好地贏得筆試和面試。由于這套面試題涉及的范圍很泛,很廣.很雜.大家不行能一天兩天就看完和學(xué)完這套面

試寶典,即使你已經(jīng)學(xué)過了有關(guān)的技術(shù),那么至少也須要一個(gè)月的時(shí)間才能消化和駕馭這套面試寶典,所以,大家應(yīng)當(dāng)

早作打算,從拿到這套面試寶典之H起,就要堅(jiān)持在每天閑暇之余學(xué)習(xí)其中幾道題目,H積月累,等到出去面試時(shí),一

切都水到渠成,面試時(shí)就自然會(huì)游刃有余了。

答題時(shí),先答是什么,再答布.什么作用和要留意什么(這部分最重.要,呈現(xiàn)自己的心得)

答案的段落分別,層次分明,條理清晰都特別重要,從這些表面的東西也可以看出一個(gè)人的習(xí)慣、辦事風(fēng)格、條理

等。

要講你做出答案的思路過程,或者說你記住答案的思想都寫下來,把答題想著是辯論賽。答題就是紿別人講道理、

擺事實(shí)。答題不局限于什么格式和形式,就是要將自己的學(xué)識(shí)呈現(xiàn)出來!

別因?yàn)槿思翌}目原來就模棱兩可,你就心里害怕和沒底氣了,不敢回答了。你要大膽地指出對(duì)方題目很模糊和你的

觀點(diǎn),不要把面試官想得有多高,其實(shí)他和你就是差不多的,你想想,假如他把你招進(jìn)去了,你們以后就是同事了,可

不是差不多的嗎?

關(guān)于就業(yè)薪水,假如你是應(yīng)屆生,那不能要高工資,好比大餅的故事,沒有文憑還想拿高工資,就去中關(guān)村缺什么

補(bǔ)什么吧!少數(shù)人基礎(chǔ)的確很好,在校期間的確又做過一些項(xiàng)目,那仍舊是可以要到相對(duì)高的工資的。

1.Java基礎(chǔ)部分

基礎(chǔ)部分的依次:基本語(yǔ)法,類相關(guān)的語(yǔ)法,內(nèi)部類的語(yǔ)法,繼承相關(guān)的語(yǔ)法,異樣的語(yǔ)法,線程的語(yǔ)法,集合的語(yǔ)法,

io的語(yǔ)法,虛擬機(jī)方面的語(yǔ)法。

1、一個(gè)Ljava"源文件中是否可以包括多個(gè)類(不是內(nèi)部類)?有

什么限制?

可以有多個(gè)類,但只能有一個(gè)public的類,并且public的類名必需與文件名相一樣。

2>Java有沒有g(shù)oto?

java中的保留字,現(xiàn)在沒有在java中運(yùn)用。

3、說說&和&&的區(qū)分。

&和&&都可以用作邏輯與的運(yùn)算符,表示邏輯與(and),當(dāng)運(yùn)弊容兩邊的表達(dá)式的結(jié)果都為true時(shí),整個(gè)運(yùn)算結(jié)果

才為true,否則,只要有一方為false,則結(jié)果為false。

&&還具有短路的功能,即假如第一個(gè)表達(dá)式為false,則不再計(jì)算其次個(gè)表達(dá)式,例如,對(duì)于if(s(r!=null

&&!str.equals(""))表達(dá)式,當(dāng)str為mill時(shí),后面的友達(dá)式不會(huì)執(zhí)行,所以不會(huì)出現(xiàn)NuUPoinierExceplion慢如將&&改為

&,則會(huì)拋出NullPoinicrExccpiion異樣。If(x==33&++y>0)y會(huì)增長(zhǎng),If(x==33&&++y>0)不會(huì)增長(zhǎng)

&還可以用作位運(yùn)算符,當(dāng)&操作符兩邊的表達(dá)式不是boolean類型時(shí),&表示按位與操作,我們通常運(yùn)用OxOf來與

一個(gè)整數(shù)進(jìn)行&運(yùn)算,來獲得該整數(shù)的最低4個(gè)bit位,例如,0x31&OxOf的結(jié)果為0x01。

備注:這道題先說兩者的共同點(diǎn),再說出&&和&的特殊之處,并列舉一些經(jīng)典的例子來表明自J理解透徹深化、實(shí)

際閱歷豐富。

4、在JAVA中如何跳出當(dāng)前的多重嵌套循環(huán)?

在Java中,要想跳出多重循環(huán),可以在外面的循環(huán)語(yǔ)句前定義一個(gè)標(biāo)號(hào),然后在里層循環(huán)體的代碼中運(yùn)用帶有標(biāo)號(hào)

的break語(yǔ)句,即可跳出外層循環(huán)。例如,

ok:

for(mti=0;i<10;i++){

for(intj=O;j<IO;j++){

Systcni.oul.println(ui=M+i+、="+j);

if(j==5)breakok;

}

1

另外,我個(gè)人通常并不運(yùn)用標(biāo)號(hào)這種方式,而是讓外層的循環(huán)條件表達(dá)式的結(jié)果可以受到里層循環(huán)體代碼的限制,

例如,要在二維數(shù)組中查找到某個(gè)數(shù)字。

intarr[]n={”23},{456.7},0};

booleanfound=false;

ibi(imi-O.i<<tn.lciig(li&&!ibund,i++){

for(intj=O;j<arrli].length;i++){

System.out.println("i="+i+”,j="+j);

?f(arr|iHj]==5){

found=(rue;

break;

}

}

I

5、switch語(yǔ)句能否作用在byte上,能否作用在long上,能否作用

在String±?

在switch(exprl)中,exprl只能是?個(gè)整數(shù)表達(dá)式或者枚舉常量(更大字體),整數(shù)表達(dá)式可以是ini基本類型或

Integer包裝類型,由于,bylc,shon,char都可以隱含轉(zhuǎn)換為int,所以,這些類型以及這些類型的包裝類型也是可以的。

明顯,long和String類型都不符合switch的語(yǔ)法規(guī)定,并且不能被隱式轉(zhuǎn)換成int類型,所以,它們不能作用于swtich

語(yǔ)句中。

6、shortsi=1;si=si+1;有什么錯(cuò)?shortsi=1;si+=1;有什么

錯(cuò)?

對(duì)于shortsi=1:si=si+1:由于sl+1運(yùn)算時(shí)會(huì)自動(dòng)提升表達(dá)式的類型,所以結(jié)果是int型,再賦值給short類型si

時(shí),編譯器將報(bào)告須要強(qiáng)制轉(zhuǎn)換類型的錯(cuò)誤。

對(duì)于shortsi=l:sl+=1:由于+=是java語(yǔ)言規(guī)定的運(yùn)算符.java編譯器會(huì)對(duì)它進(jìn)行特殊處理,因此可以正確編譯。

7、char型變量中能不能存貯一個(gè)中文漢字?為什么?

chai■型變量是用來存儲(chǔ)Unicode編碼的字符的,Unicode編碼字符集中包含了漢字,所以,char型變量中當(dāng)然可以存

儲(chǔ)漢字啦。不過,假如某個(gè)特殊的漢字沒有被包含在unicode編碼字符集中,那么,這個(gè)char型變量中就不能存儲(chǔ)這個(gè)

特殊漢字。補(bǔ)充說明:unicode編碼占用兩個(gè)字節(jié),所以,char類型的變量也是占用兩個(gè)字節(jié)。

備注:后面一部分回答雖然不是在正面回答題但是,為了呈現(xiàn)自己的學(xué)識(shí)和表現(xiàn)自己對(duì)問題理解的透徹深化,

可以回答一些相關(guān)的學(xué)問,做到知無不言,言無不盡。

8、用最有效率的方法算出2乘以8等於幾?

2?3,

因?yàn)閷⒁粋€(gè)數(shù)左移n位,就相當(dāng)于乘以了2的n次方,那么,一個(gè)數(shù)乘以8只要將其左移3位即可,而位運(yùn)算epu

干脆支持的,效率最高,所以,2乘以8等於兒的最效率的方法是2<<3。

9、請(qǐng)?jiān)O(shè)計(jì)一個(gè)一百億的計(jì)算器

首先要明白這道題目的考查點(diǎn)是什么,一是大家首先要對(duì)計(jì)算機(jī)原理的底層細(xì)微環(huán)節(jié)要清晰、要知道加減法的位運(yùn)

算原理和知道計(jì)算機(jī)中的算術(shù)運(yùn)算會(huì)發(fā)生越界的狀況,二是要具備確定的面對(duì)對(duì)象的設(shè)計(jì)思想。

首先,計(jì)算機(jī)中用固定數(shù)量的幾個(gè)字節(jié)來存儲(chǔ)的數(shù)值,所以計(jì)算機(jī)中能夠表示的數(shù)值是有確定的范圍的,為了便于

講解和理解.,我們先以byle類型的整數(shù)為例,它用1個(gè)字節(jié)進(jìn)行存儲(chǔ),表示的最大數(shù)值范圍為?128到+127。/在內(nèi)存

中對(duì)應(yīng)的二進(jìn)制數(shù)據(jù)為11111111,假如兩個(gè)-1相加,不考慮Java運(yùn)算時(shí)的類型提升,運(yùn)算后會(huì)產(chǎn)生進(jìn)位,二進(jìn)制結(jié)果為

1,11111110,由于進(jìn)位后超過了by【c類型的存儲(chǔ)空間,所以進(jìn)位部分被舍棄,即最終的結(jié)果為11111110,也就是?2,這

正好利用溢位的方式實(shí)現(xiàn)了負(fù)數(shù)的運(yùn)算。-128在內(nèi)存中對(duì)應(yīng)的二進(jìn)制數(shù)據(jù)為10000000,假如兩個(gè)-128相加,不考慮Java

運(yùn)算時(shí)的類型提升,運(yùn)算后會(huì)產(chǎn)生進(jìn)位,二進(jìn)制結(jié)果為1,00000000,U于進(jìn)位后超過了byle類型的存儲(chǔ)空間,所以進(jìn)位

部分被舍棄,即最終的結(jié)果為(XX)OOO(X),也就是0,這樣的結(jié)果明顯不是我們期望的,這說明計(jì)算機(jī)中的算術(shù)運(yùn)算是會(huì)

發(fā)生越界狀況的,兩個(gè)數(shù)值的運(yùn)算結(jié)果不能超過計(jì)算機(jī)中的該類型的數(shù)值范圍。由于Java中涉及表達(dá)式運(yùn)算時(shí)的類型自

動(dòng)提升,我們無法用byle類型來做演示這種問題和現(xiàn)象的試驗(yàn),大家可以用下面一個(gè)運(yùn)用整數(shù)做試驗(yàn)的例子程序體驗(yàn)一

下:

inta=Integer.MAX_VALUE;

intb=Integer.MAX_VALUE;

intsum=a+b;

Systcm.out.printlnC'a=',+a+,\b=,,+b+,,,sum=,,+sum);

先不考慮long類型,由于ini的正數(shù)范圍為2的31次方,表示的最大數(shù)值約等于2*1000*1000*1000,也就是20億

的大小,所以,要實(shí)現(xiàn)一個(gè)一百億的計(jì)算器,我們得自己設(shè)計(jì)一個(gè)類可以用于表示很大的整數(shù).并且供應(yīng)了與另外一個(gè)

整數(shù)進(jìn)行加減乘除的功能,或許功能如卜.:

()這個(gè)類內(nèi)部有兩個(gè)成員變量,一個(gè)表示符號(hào),另一個(gè)用字節(jié)數(shù)組表示數(shù)值的二進(jìn)制數(shù)

()有一個(gè)構(gòu)造方法,把一個(gè)包含有多位數(shù)值的字符串轉(zhuǎn)換到內(nèi)部的符號(hào)和字節(jié)數(shù)組中

()供應(yīng)加減乘除的功能

publicclassBiglnteger{

intsign;

byte[]val;

publicBiginteger(Stringval){

sign=;

val

)

publicBigintegeradd(Bigintegerother){

}

publicBigintcgcrsubtracKBiglntcgcrother){

}

publicBigintegermultiply(Bigintegerother){

}

publicBigintegerdivide(Bigintegerother){

}

備注:要想寫出這個(gè)類的完整代碼,是特別困難的,假如有愛好的話,可以參看jdk中自帶的java.math.Biglniegcr

類的源碼。面試的人也知道誰都不行能在短時(shí)間內(nèi)寫出這個(gè)類的完整代碼的,他要的是你是否有這方面的概念和意識(shí),

他最重要的還是考查你的實(shí)力,所以,你不要因?yàn)樽约簾o法寫出完整的最終結(jié)果就放棄答這道題,你要做的就是你比別

人寫得多,證明你比別人強(qiáng),你有這方面的思想意識(shí)就可以了,終歸別人可能連題目的意思都看不懂,什么都沒寫,你

要敢于答這道題,即使只答了一部分,那也與那些什么都不懂的人區(qū)分出來,拉開了距離,算是矮子中的高個(gè),機(jī)會(huì)當(dāng)

然就屬于你了。另外,答案中的框架代碼也很重要,體現(xiàn)了一些面對(duì)對(duì)象設(shè)計(jì)的功底,特殊是其中的方法命名很專業(yè),

用的英文單詞很精準(zhǔn),這也是實(shí)力、閱歷、專業(yè)性、英語(yǔ)水同等多個(gè)方面的體現(xiàn),會(huì)給人留下很好的印蒙,在編程實(shí)力

和其他方面條件差不多的狀況下,英語(yǔ)好除了可以使你獲得更多機(jī)會(huì)外,薪水可以高出一千元。

10、運(yùn)用final關(guān)鍵字修飾一個(gè)變量時(shí),是引用不能變,還是引用的

對(duì)象不能變?

運(yùn)用final關(guān)鍵字修飾一個(gè)變量時(shí),是指引用變量不能變,引用變量所指向的對(duì)象中的內(nèi)容還是可以變更的。例如,

對(duì)于如下語(yǔ)句:

finalStringBuffera=newStringBuffer("immutable");

執(zhí)行如下語(yǔ)句將報(bào)告編譯期錯(cuò)誤:

a=newStringBufter("");

但是,執(zhí)行如下語(yǔ)句則可以通過編譯:

a.appcnd("broken!");

有人在定義方法的參數(shù)時(shí),可能想采納如下形式來阻擋方法內(nèi)部修改傳進(jìn)來的參數(shù)對(duì)象:

publicvoidmethod(finalStringBufferparam)(

I

事實(shí)上,這是辦不到的,在該方法內(nèi)部仍舊可以增加如下代碼來修改參數(shù)對(duì)象:

param.append("a");

11、和equals方法原委有什么區(qū)分?

(單獨(dú)把一個(gè)東西說清晰,然后再說清晰另一個(gè),這樣,它們的區(qū)分自然就出來了,混在一起說,貝j很難說清晰)

==操作符特地用來比較兩個(gè)變量的值是否相等,也就是用于比較變量所對(duì)應(yīng)的內(nèi)存中所存儲(chǔ)的數(shù)值是否相同,要比

較兩個(gè)基本類型的數(shù)據(jù)或兩個(gè)引用變量是否相等,只能用==操作符。

假如一個(gè)變量指向的數(shù)據(jù)是對(duì)象類型的,那么,這時(shí)候涉及了兩塊內(nèi)存,對(duì)象本身占用一塊內(nèi)存(堆內(nèi)存),變量也

占用一塊內(nèi)存,例如Obje【obj=newObject。;變量obj是一個(gè)內(nèi)存,newObject。是另一個(gè)內(nèi)存,此時(shí),變他obj所對(duì)應(yīng)的

內(nèi)存中存儲(chǔ)的數(shù)值就是對(duì)象占用的那塊內(nèi)存的首地址。對(duì)于指向?qū)ο箢愋偷淖兞浚偃缫容^兩個(gè)變量是否指向同一個(gè)

對(duì)象,即要看這兩個(gè)變量所對(duì)應(yīng)的內(nèi)存中的數(shù)值是否相等,這時(shí)候就須要用==操作符進(jìn)行比較。

equals方法是用于比較兩個(gè)獨(dú)立對(duì)象的內(nèi)容是否相同,就好比去比較兩個(gè)人的長(zhǎng)相是否相同,它比依的兩個(gè)對(duì)象是

獨(dú)立的。例如,對(duì)于下面的代碼:

Stringa=newStringCfoo'1);

Stringb=ncwString("foo");

兩條new語(yǔ)句創(chuàng)建了兩個(gè)對(duì)象,然后用a,b這兩個(gè)變量分別指向了其中一個(gè)對(duì)象,這是兩個(gè)不同的對(duì)象,它們的首

地址是不同的,即a和b中存儲(chǔ)的數(shù)值是不相同的,所以,表達(dá)式a==b將返回false,而這兩個(gè)對(duì)象中的內(nèi)容是相同的,

所以,表達(dá)式a.equals(b)將返回true。

在實(shí)際開發(fā)中,我們常常要比較傳遞進(jìn)行來的字符串內(nèi)容是否等,例如,Siringinput=...;inpul.cquals(-quiO,很多

人稍不留意就運(yùn)用==進(jìn)行比較了,這是錯(cuò)誤的,隨意從網(wǎng)上找?guī)讉€(gè)項(xiàng)目實(shí)戰(zhàn)的教學(xué)視頻看看,里面就有大量這樣的錯(cuò)誤。

記住,字符串的比菽基本上都是運(yùn)用equals方法。

假如一個(gè)類沒有自己定義equals方法,那么它將繼承Object類的equals方法,Object類的equals方法的實(shí)現(xiàn)代碼如

下:

booleancquals(Objccto){

returnthis==o;

)

這說明,假如一個(gè)類沒有自己定義equals方法,它默認(rèn)的equals方法(從Object類繼承的)就是運(yùn)用==操作符,

也是在比較兩個(gè)變量指向的對(duì)象是否是同一對(duì)象,這時(shí)候運(yùn)用equals和運(yùn)用==會(huì)得到同樣的結(jié)果,假如比較的是兩個(gè)獨(dú)

立的對(duì)象則總返回false。假如你編寫的類冷望能夠比較該類創(chuàng)建的兩個(gè)實(shí)例對(duì)象的內(nèi)容是否相同,那么你必需覆蓋equals

方法,由你自己寫代碼來確定在什么狀況即可認(rèn)為兩個(gè)對(duì)象的內(nèi)容是相同的。

12、靜態(tài)變量和實(shí)例變量的區(qū)分?

在語(yǔ)法定義上的區(qū)分:靜態(tài)變量前要加static美鍵字,而實(shí)例變員前則不加。

在程序運(yùn)行時(shí)的區(qū)分:實(shí)例變量屬于?某個(gè)對(duì)象的屬性,必需創(chuàng)建了實(shí)例對(duì)象,其中的實(shí)例變量才會(huì)被安排空間,才

能運(yùn)用這個(gè)實(shí)例變量。靜態(tài)變量不屬于某個(gè)實(shí)例對(duì)象,而是屬于類,所以也稱為類變量,只要程序加載了類的字節(jié)碼,

不用創(chuàng)建任何實(shí)例對(duì)象,靜態(tài)變量就會(huì)被安排空間,靜態(tài)變量就可以被運(yùn)用了??傊?,實(shí)例變量必需創(chuàng)建對(duì)象后才可以

通過這個(gè)對(duì)象來運(yùn)用,靜態(tài)變量則叮以干脆運(yùn)用類名來引用。

例如,對(duì)于下面的程序,無論創(chuàng)建多少個(gè)實(shí)例對(duì)象,恒久都只安排了?個(gè)staticVar變量,并且每創(chuàng)建?個(gè)實(shí)例對(duì)象,

這個(gè)staiicVar就會(huì)加1;但是,每創(chuàng)建一個(gè)實(shí)例對(duì)象,就會(huì)安排一個(gè)instanceVar,即可能安排多個(gè)insianceVar,并且每

個(gè)instanceVar的值都只自加了I次。

publicclassVariantTest{

publicstaticintslaticVar=0;

publicintinstanceVar=0;

publicVariantTcst(){

staticVar++;

instanceVar++;

Sys【em.oul.priniln("slaiicVar="+staticVar+”,instanceVar=''+instanceVar);

)

備注:這個(gè)解答除了說清晰兩者的區(qū)分外,最終還用一個(gè)具體的應(yīng)用例子來說明兩者的差異,體現(xiàn)了自己有很好的

解說問題和設(shè)計(jì)案例的實(shí)力,思維靈敏,超過一?般程序員,有寫作實(shí)力!

13、是否可以從一個(gè)static方法內(nèi)部發(fā)出對(duì)非static方法的調(diào)用?

不行以。因?yàn)榉莝tatic方法是要與對(duì)象關(guān)聯(lián)在一起的,必需創(chuàng)建一個(gè)對(duì)象后,才可以在該對(duì)象上進(jìn)行方法調(diào)用,而

stat沁方法調(diào)用時(shí)不須要?jiǎng)?chuàng)建對(duì)象,可以干脆調(diào)用.也就是說,當(dāng)?個(gè)static方法被調(diào)用時(shí),可能還沒有包建任何實(shí)例對(duì)

象,假如從一個(gè)sialic方法中發(fā)出對(duì)非sialic方法的調(diào)用,那個(gè)非sia位方法是關(guān)聯(lián)到哪個(gè)對(duì)象上的呢?這個(gè)邏輯無法成

立,所以,個(gè)static方法內(nèi)部發(fā)出對(duì)非static方法的調(diào)用。

14、Integer與int的區(qū)分

int是java供應(yīng)的8種原始數(shù)據(jù)類型之一。Java為每個(gè)原始類型供應(yīng)了封裝類,Integer是java為int供應(yīng)的封裝類。

int的默認(rèn)值為0,而Integer的默認(rèn)值為null,即Integer可以區(qū)分出未賦值和值為。的區(qū)分,int則無法表達(dá)出未賦值的

狀況,例如,要想表達(dá)出沒有參與考試和考試成果為0的區(qū)分,則只能區(qū)用Integer。在JSP開發(fā)中,Integer的默認(rèn)為null,

所以用el表達(dá)式在文本框中顯示時(shí),值為空白字符串,而ini默認(rèn)的默認(rèn)值為0,所以用el表達(dá)式在文本框中顯示時(shí),

結(jié)果為0,所以,ini不適合作為web層的表單數(shù)據(jù)的類型。

在Hibernate中,假如將OID定義為Integer類型,那么Hibernate就可以依據(jù)其值是否為null而推斷一個(gè)對(duì)象是否

是臨時(shí)的,假如將OID定義為了ini類型,還須要在hbn】映射文件中設(shè)置其unsaved-value屬性為0。

另外,Integer供應(yīng)了多個(gè)與整數(shù)相關(guān)的操作方法,例如,將一個(gè)字符串轉(zhuǎn)換成整數(shù),Integer中還定義了表示整數(shù)的

最大值和最小值的常量。

15、Math.round(ll?5)等於多少?Math.roundGH.5)等於多少?

Math類中供應(yīng)了三個(gè)與取整有關(guān)的方法:ceil、floor、round,這些方法的作用與它們的英文名稱的含義相對(duì)應(yīng),例

如,ceil的英文意義是天花板,該方法就表示向上取整,Math.ceil(11.3)的結(jié)果為12,Maih.ceil(-1L3)的結(jié)果是-11:floor

的英文意義是地板,該方法就表示向下取整,Malh.ceil⑴.6)的結(jié)果為ll,Malh.ceil(-l1.6)的結(jié)果是-12;最難駕馭的是round

方法,它表示“四舍五入”,算法為Math.floor(x+0.5),即將原來的數(shù)字加上0.5后再向下取整,所以,Math.round(l1.5)

的結(jié)果為12,Math.round(-1L5)的結(jié)果為-11。

16、下面的代碼有什么不妥之處?

1.if(username.equals(uzxx,){}

2.intx=1;

returnx==l?tnie:false;

17、請(qǐng)說出作用域public,private,protected,以及不寫時(shí)的區(qū)分

這四個(gè)作用域的可見范圍如下表所示。

說明:假如代修飾的元素上面沒有寫任何訪問修飾符,則表示friendly。

作用域當(dāng)前類|SJ—package子孫類其他package

publicJJJJ

protectedJJVX

friendlyJJXX

privateJXXX

備注:只要記住了有4種訪何權(quán)限,4個(gè)訪問范圍,然后將全選用范圍在水平和垂直方向上分別按揉從小到大或從

大到小的依次排列,就很簡(jiǎn)潔畫出上面的圖了。

18、Overload和Override的區(qū)分。Overloaded的方法是否可以變

更返回值的類型?

Overload是重載的意思,Oveeide是覆蓋的意思,也就是重寫。

市載Overload表示同一個(gè)類中可以有多個(gè)名稱相同的方法,但這些方法的參數(shù)列表各不相同(即參數(shù)個(gè)數(shù)或類型不

同)。

重寫Override表示子類中的方法可以與父類中的某個(gè)方法的名稱和參數(shù)完全相同,通過子類創(chuàng)建的實(shí)例對(duì)象調(diào)用這

個(gè)方法時(shí),將調(diào)用/類中的定義方法,這相當(dāng)丁把父類中定義的那個(gè)完全相同的方法給覆蓋了,這也是面對(duì)刻象編程的

多態(tài)性的一種表現(xiàn)。子類覆蓋父類的方法時(shí),只能比父類拋出更少的異樣,或者是拋出父類拋出的異樣的子異樣,因?yàn)?/p>

子類可以解決父類的一些問題,不能比父類有更多的問題。子類方法的訪問權(quán)限只能比父類的更大,不能更小。假如父

類的方法是private類型,那么,子類則不存在覆蓋的限制,相當(dāng)于子類中增加了一個(gè)全新的方法。

至于Overloaded的方法是否可以變更返回值的類型這個(gè)問題,要看你倒底想問什么呢?這個(gè)題目很模糊。假如幾個(gè)

Overloaded的方法的參數(shù)列表不一樣,它們的返回者類型當(dāng)然也可以不一樣。但我估計(jì)你想問的問題是:假如兩個(gè)方法

的參數(shù)列表完全一樣,是否可以讓它們的返回值不同來實(shí)現(xiàn)重載OvcHoad。這是不行的,我們可以用反證法來說明這個(gè)

問題,因?yàn)槲覀冇袝r(shí)候調(diào)用一個(gè)方法時(shí)也可以不定義返回結(jié)果變量,即不要關(guān)切其返回結(jié)果,例如,我們調(diào)用

m叩.rcmovc(kcy)方法時(shí),雖然remove方法有返回值,但是我們通常都不會(huì)定義接收返回結(jié)果的變量,這時(shí)候假設(shè)該類

中有兩個(gè)名稱和參數(shù)列表完全相同的方法,僅僅是返回類型不同,java就無法確定編程者倒底是想調(diào)用哪個(gè)方法了,因

為它無法通過返回結(jié)果類型來推斷。

override可以翻譯為覆蓋,從字面就可以知道,它是覆蓋了一個(gè)方法并且對(duì)其重寫,以求達(dá)到不同的作

用。對(duì)我們來說最熟識(shí)的覆蓋就是對(duì)接口方法的實(shí)現(xiàn),在接口中一般只是對(duì)方法進(jìn)行了聲明,而我們?cè)?/p>

實(shí)現(xiàn)時(shí),就須要實(shí)現(xiàn)接口聲明的全部方法。除了這個(gè)典型的用法以外,我們?cè)诶^承中也可能會(huì)在子類覆

蓋父類中的方法。在覆蓋要留意以下的幾點(diǎn):

1、覆蓋的方法的標(biāo)記必須要和被覆蓋的方法的標(biāo)記完全匹配,才能達(dá)到覆蓋的效果;

2、覆蓋的方法的返回值必需和被覆蓋的方法的返回一樣:

3、覆蓋的方法所拋出的異樣必需和被覆蓋方法的所拋出的異樣一樣,或者是其子類;

4、被覆蓋的方法不能為private,否則在其子類中只是新定義了一個(gè)方法,并沒有對(duì)其進(jìn)行覆蓋。

overload對(duì)我們來說可能比較熟識(shí),可以翻譯為重載,它是指我們可以定義一些名稱相同的方法,通

過定義不同的輸入?yún)?shù)來區(qū)分這些方法,然后再調(diào)用時(shí),VM就會(huì)依據(jù)不同的參數(shù)樣式,來選擇合適的

方法執(zhí)行。在運(yùn)用重載要留意以下的幾點(diǎn):

1、在運(yùn)用重載時(shí)只能通過不同的參數(shù)樣式。例如,不同的參數(shù)類型,不同的參數(shù)個(gè)數(shù),不同的參數(shù)依

次(當(dāng)然,同一方法內(nèi)的幾個(gè)參數(shù)類型必需不一樣,例如可以是fun(int,float),但是不能為fun(intjnt));

2、不能通過訪問權(quán)限、返回類型、拋出的異樣進(jìn)行重載;

3、方法的異樣類型和數(shù)目不會(huì)對(duì)重載造成影響;

4、對(duì)于繼承來說,假如某一方法在父類中是訪問權(quán)限是priavle,那么就不能在子類對(duì)其

進(jìn)行重載,假如定義的話,也只是定義了一個(gè)新方法,而不會(huì)達(dá)到重載的效果。

19、構(gòu)造器Constructor是否可被override?

構(gòu)造器Constructor不能被繼承,因此不能重寫Override,但可以被重載Overload。

20、接口是否可繼承接口?抽象類是否可實(shí)現(xiàn)(implements)接口?抽

象類是否可繼承具體類(concreteclass)?抽象類中是否可以有靜態(tài)

的main方法?

接口可以繼承接口。抽象類可以實(shí)現(xiàn)(implements)接口,抽象類是否可繼承具體類。抽象類中可以有靜態(tài)的main方

法。

備注:只要明白了接口和抽象類的本質(zhì)和作用,這些問題都很好回答,你想想,假如你是java語(yǔ)言的設(shè)計(jì)者,你是

否會(huì)供應(yīng)這樣的支持,假如不供應(yīng)的話,有什么理由嗎?假如你沒有道理不供應(yīng),那答案就是確定的

只有記住抽象類與一般類的唯一區(qū)分就是不能創(chuàng)建實(shí)例對(duì)象和允許有abstract方法。

21、寫clone。方法時(shí),通常都有一行代碼,是什么?

clone有缺省行為,super.clone。;因?yàn)槭紫纫迅割愔械某蓡T復(fù)制到位,然后才是復(fù)制自己的成員。

22、面對(duì)對(duì)象的特征有哪些方面

計(jì)算機(jī)軟件系統(tǒng)是現(xiàn)實(shí)牛.活中的業(yè)務(wù)在計(jì)算機(jī)中的映射,而現(xiàn)實(shí)牛?活中的業(yè)務(wù)其實(shí)就是一個(gè)個(gè)對(duì)象協(xié)作的過程。面

對(duì)對(duì)象編程就是按現(xiàn)實(shí)業(yè)務(wù)一樣的方式將程序代碼按一個(gè)個(gè)對(duì)象進(jìn)行組織和編寫,讓計(jì)算機(jī)系統(tǒng)能夠識(shí)另J和理解用對(duì)象

方式組織和編寫的程序代碼,這樣就可以把現(xiàn)實(shí)生活中的業(yè)務(wù)對(duì)象映射到計(jì)算機(jī)系統(tǒng)中。

面對(duì)對(duì)象的編程語(yǔ)言有封裝、繼承、抽象、多態(tài)等4個(gè)主要的特征。

1封裝:

封裝是保證軟件部件具有優(yōu)良的模塊性的基礎(chǔ),封裝的目標(biāo)就是要實(shí)現(xiàn)軟件部件的“高內(nèi)聚、低耦合”,防止

程序相互依靠性而帶來的變動(dòng)影響。在面對(duì)對(duì)象的編程語(yǔ)言中,對(duì)象是封裝的最基本單位,面對(duì)對(duì)象的封裝比傳

統(tǒng)語(yǔ)言的封裝更為清晰、更為有力。面對(duì)對(duì)象的封裝就是把描述?個(gè)對(duì)象的屬性和行為的代碼封裝在個(gè)“模塊”中,

也就是一個(gè)類中,屬性用變量定義,行為用方法進(jìn)行定義,方法可以干脆訪問同一個(gè)對(duì)象中的屬性。通常狀況下,只要

記住讓變量和訪問這個(gè)變量的方法放在一起,將一個(gè)類中的成員變量全部定義成私有的,只有這個(gè)類自己的方法才可以

訪問到這些成員變量,這就基本上實(shí)現(xiàn)對(duì)象的封裝,就很簡(jiǎn)潔找出要安排到這個(gè)類上的方法了,就基本上算是會(huì)面對(duì)對(duì)

象的編程了。把握一個(gè)原則:把對(duì)同一事物進(jìn)行操作的方法和相關(guān)的方法放在同一個(gè)類中,把方法和它操作的數(shù)據(jù)放在

同一個(gè)類中。

例如,人要在黑板上畫圓,這一共涉及三個(gè)對(duì)象:人、黑板、圓,畫圓的方法要安排給哪個(gè)時(shí)象呢?由于畫圓須要

運(yùn)用到圓心和半徑,圓心和半徑明顯是圓的屬性,假如將它們?cè)陬愔卸x成了私有的成員變量,那么,面圓的方法必需

安排給圓,它才能訪問到圓心和半徑這兩個(gè)屬性,人以后只是調(diào)用圓的畫圓方法、表示給圓發(fā)給消息而已,畫圓這個(gè)方

法不應(yīng)當(dāng)安排在人這個(gè)對(duì)象上,這就是面對(duì)對(duì)象的封裝性,即將對(duì)象封裝成一個(gè)高度自治和相對(duì)封閉的個(gè)體,對(duì)象狀態(tài)

(屬性)由這個(gè)對(duì)象自己的行為(方法)來讀取和變更。一個(gè)更便于理解的例子就是,司機(jī)將火車剎住了,剎車的動(dòng)作

是安排給司機(jī),還是安排給火車,明顯,應(yīng)當(dāng)安排給火車,囚為司機(jī)自身是不行能有那么大的力氣將一個(gè)火車給停下來

的,只有火車自己才能完成這一動(dòng)作,火車須要調(diào)用內(nèi)部的離合器和剎車片等多個(gè)器件協(xié)作才能完成剎車這個(gè)動(dòng)作,司

機(jī)剎車的過程只是給火車發(fā)了一個(gè)消息,通知火車要執(zhí)行剎車動(dòng)作而已。

抽象:

抽象就是找出一些事物的相喙和共性之處,然后將這些事物歸為一個(gè)類,這個(gè)類只考慮這些事物的相像和共

性之處,并且會(huì)忽視與當(dāng)前主題和目標(biāo)無關(guān)的那些方面,將留意力集中在與當(dāng)前目標(biāo)有關(guān)的方面。例如,看到一

只螞蟻和大象,你能夠想象出它們的相同之處,那就是抽象。抽蒙包括行為抽象和狀態(tài)抽象兩個(gè)方面。例如,定

義一個(gè)Person類,如下:

classPerson{

Stringname;

intage;

)

人原來是很困難的事物,有很多方面,但因?yàn)楫?dāng)前系統(tǒng)只須要了解人的姓名和年齡,所以上面定義的類中只

包含姓名和年齡這兩個(gè)屬性,這就是一種抽像,運(yùn)用抽象可以避開考慮一些與目標(biāo)無關(guān)的細(xì)微環(huán)節(jié)。我對(duì)抽象的

理解就是不要用顯微鏡去看一個(gè)事物的全部方面,這樣涉及的內(nèi)容就太多了,而是要擅長(zhǎng)劃分問題的邊界,當(dāng)前

系統(tǒng)須要什么,就只考慮什么。

繼承:

在定義和實(shí)現(xiàn)一個(gè)類的時(shí)候,可以在一個(gè)已經(jīng)存在的類的基礎(chǔ)之上來進(jìn)行,把這個(gè)已經(jīng)存在的類所定義的內(nèi)

容作為自己的內(nèi)容,并可以加入若干新的內(nèi)容,或修改原來的方法使之更適合特殊的須要,這就是繼承。繼承是

子類自動(dòng)共享父類數(shù)據(jù)和方法的機(jī)制,這是類之間的一種關(guān)系,提高了軟件的可重用性和可擴(kuò)展性。

多態(tài):

多態(tài)是指程序中定義的引用變最所指向的具體類型和通過該引用變量發(fā)出的方法調(diào)用在編程時(shí)并不確定,而

是在程序運(yùn)行期間才確定,即一個(gè)引用變量倒底會(huì)指向哪個(gè)類的實(shí)例對(duì)象,該引用變量發(fā)出的方法調(diào)用究竟是哪

個(gè)類中實(shí)現(xiàn)的方法,必需在由程序運(yùn)行期間才能確定。因?yàn)樵诔绦蜻\(yùn)行時(shí)才確定具體的類,這樣,不用修改源程

序代碼,就可以讓引用變量綁定到各種不同的類實(shí)現(xiàn)上,從而導(dǎo)致該引用調(diào)用的具體方法隨之變更,即不修

改程序代碼就可以變更程序運(yùn)行時(shí)所綁定的具體代碼,讓程序可以選擇多個(gè)運(yùn)行狀態(tài),這就是多態(tài)性。

多態(tài)性增加了軟件的敏捷性和擴(kuò)展性。例如,下面代碼中的UserDa。是一個(gè)接口,它定義引用變量userDa。指

向的實(shí)例對(duì)象由daofaciory.gelDao。在執(zhí)行的時(shí)候返歸I,有時(shí)候指向的是UserJdbcDao這個(gè)實(shí)現(xiàn),有時(shí)候

指向的是UserHibemateDao這個(gè)實(shí)現(xiàn),這樣,不用修改源代碼,就可以變更userDao指向的具體類實(shí)現(xiàn),

從而導(dǎo)致userDao.inseriUser。方法調(diào)用的具體代碼也隨之變更,即有時(shí)候調(diào)用的是UserJdbcDao的

insertUser方法,有時(shí)候調(diào)用的是UserHibernateDao的insertUser方法:

UscrDaouscrDao=daofactory.gctDao();

userDao.insertUser(user);

比方:人吃飯,你看到的是左手,還是右手?

23、java中實(shí)現(xiàn)多態(tài)的機(jī)制是什么?

靠的是父類或接口定義的引用變量可以指向子類或具體實(shí)現(xiàn)類的實(shí)例對(duì)象,而程序調(diào)用的方法在運(yùn)行期才動(dòng)

態(tài)綁定,就是引用變量所指向的具體實(shí)例對(duì)象的方法,也就是內(nèi)存里正在運(yùn)行的那個(gè)對(duì)象的方法,而不是引用變

量的類型中定義的方法。

24^abstractclass和interface有什么區(qū)分?

含有abstract修飾符的class即為抽象類,abstract類不能創(chuàng)建的實(shí)例對(duì)象。含有abstract方法的類必需定義為abstract

class,abstractclass類中的方法不必是抽象的。abstractclass類中定義抽象方法必需在具體(Concrete)子類中實(shí)現(xiàn),所以,

不能有抽象構(gòu)造方法或抽象靜態(tài)方法。假如的子類沒有實(shí)現(xiàn)抽象父類中的全部抽象方法,那么子類也必需定義為abstract

類型。

接口(interface)可以說成是抽象類的一種特例,接口中的全部方法都必需是抽象的。接口中的方法定義默認(rèn)為public

abstract類型,接口中的成員變量類型默認(rèn)為publicstaticfinalo

下面比較一下兩者的語(yǔ)法區(qū)分:

1.抽象類可以有構(gòu)造方法,接口中不能有構(gòu)造方法。

2.抽象類中可以有一般成員變量,接口中沒有一般成員變量

3.抽象類中可以包含非抽象的一般方法,接口中的全部方法必需都是抽象的,不能有非抽象的一般方法。

4.抽象類中的抽象方法的訪問類型可以是public,protected和(默認(rèn)類型,雖然

eclipse下不報(bào)錯(cuò),但應(yīng)當(dāng)也不行),但接口中的抽象方法只能是public類型的,并且默認(rèn)即為publicabstract類型。

5.抽象類中可以包含靜態(tài)方法,接口中不能包含靜態(tài)方法

6.抽象類和接口中都可以包含靜態(tài)成員變量,抽象類中的靜態(tài)成員變量的訪問類型可以隨意,但接口中定義的變量

只能是publicstaticfinal類型,并且默認(rèn)即為publicstaticfinal類型。

7.一個(gè)類可以實(shí)現(xiàn)多個(gè)接口,但只能繼承一個(gè)抽象類。

卜曲接看再說說兩者在應(yīng)用上的區(qū)分:

接口更多的是在系統(tǒng)架構(gòu)設(shè)計(jì)方法發(fā)揮作用,主要用于定義模塊之間的通信契約。而抽象類在代碼實(shí)現(xiàn)方面發(fā)揮作

用,可以實(shí)現(xiàn)代碼的重用,例如,琪板方法設(shè)計(jì)模式是抽象類的一個(gè)典型應(yīng)用,假設(shè)某個(gè)項(xiàng)目的全部Servlel類都要用相

同的方式進(jìn)行權(quán)限推斷、記錄訪問日志和處理異樣,那么就可以定義一個(gè)抽象的基類,讓全部的Servlel招繼承這個(gè)抽象

基類,在抽象基類的service方法中完成權(quán)限推斷、記錄訪問日志和處理異樣的代碼,在各個(gè)子類中只是完成各自的業(yè)務(wù)

邏輯代碼,偽代碼如下:

publicabstractclassBaseServletextendsServlet{

publicfinalvoidservice(SenletRequestrequest,ServletResponseresponse)throws

IOExcetion,ServletException(

記錄訪問日志

進(jìn)行權(quán)限推斷

if(具有權(quán)限)(

lry{

doService(request.response);

}

catch(Excelpione){

記錄異樣信息

)

)

}

protectedabstractvoiddoService(ServletRequestrequest.ServletResponseresponse)throws

lOExcetion.ServletException;

〃留意訪問權(quán)限定義成protect4,顯得既專業(yè),又嚴(yán)謹(jǐn),因?yàn)樗翘氐亟o子類用的

)

publicclassMyServletIextendsBaseServlet

protectedvoiddoService(ServletRequestrequest,ServletResponseresponse)throws

lOExceiion.ServletException

(

本Servlet只處理的具體業(yè)務(wù)邏輯代碼

父類方法中間的某段代碼不確定,留給子類干,就用模板方法設(shè)計(jì)模式。

備注:這道題的思路是先從總體說明抽象類和接口的基本概念,然后再比較兩者的語(yǔ)法細(xì)微環(huán)節(jié),最終再說兩者的

應(yīng)用區(qū)分。比較兩者語(yǔ)法細(xì)微環(huán)節(jié)區(qū)分的條理是:先從一個(gè)類中的構(gòu)造方法、一般成員變量和方法(包括抽象方法),靜

態(tài)變量和方法,繼承性等6個(gè)方血逐一去比較回答,接著從第三者繼承的角度的回答,特殊是最終用了一個(gè)典型的例子

來呈現(xiàn)自己深厚的技術(shù)功底。

25、abstract的method是否可同時(shí)是static,是否可同時(shí)是native,

是否可同時(shí)是synchronized?

abstractWmethod不行以是static的,因?yàn)槌橄蟮姆椒ㄊ且蛔宇悓?shí)現(xiàn)的,而slulic與子類扯不上關(guān)系!

native方法表示該方法要用另外種依靠平臺(tái)的編程語(yǔ)言實(shí)現(xiàn)的,不存在若被了類實(shí)現(xiàn)的問題,所以,它也不能是

抽象的,不能與absiraci混用。例如,F(xiàn)ilcOulpulSlcam類要硬件打交道,底層的實(shí)現(xiàn)用的是操作系統(tǒng)相關(guān)的叩i實(shí)現(xiàn),例

如,在windows用c語(yǔ)言實(shí)現(xiàn)的,所以,查看jdk的源代碼,可以發(fā)覺FileOutputStream的open方法的足義如下:

privatenativevoidopen(Slringname)throwsFileNotFoundException;

假如我們要用java調(diào)用別人寫的c語(yǔ)言函數(shù),我們是無法干脆調(diào)用的,我們須要依據(jù)java的要求寫一個(gè)c語(yǔ)言的函

數(shù),又我們的這個(gè)c語(yǔ)言函數(shù)去調(diào)用別人的c語(yǔ)言函數(shù)。由于我們的c語(yǔ)言函數(shù)是按java的要求來寫的,我們這個(gè)c語(yǔ)

言函數(shù)就可以與java對(duì)接上,java那邊的對(duì)接方式就是定義出與我們3個(gè)c函數(shù)相對(duì)應(yīng)的方法,java中對(duì)應(yīng)的方法不須

要寫具體的代碼,但須要在前面聲明nativeo

關(guān)于synchronized與absiraci合用的問題,我覺得也不行,因?yàn)樵谖規(guī)啄甑膶W(xué)習(xí)和開發(fā)中,從來沒見到過這種狀況,

并且我覺得synchronized應(yīng)當(dāng)是作用在一個(gè)具體的方法上才有怠義。而且,方法上的synchronized同步所運(yùn)用的同步鎖

對(duì)象是【his,而抽象方法上無法確定this是什么。

26、什么是內(nèi)部類?StaticNestedClass和InnerClass的不同。

內(nèi)部類就是在?個(gè)類的內(nèi)部定義的類,內(nèi)部類中不能定義靜態(tài)成員(靜態(tài)成員不是對(duì)象的特性,只是為r找?個(gè)容

身之處,所以須要放到一個(gè)類中而已,這么一點(diǎn)小事,你還要把它放到類內(nèi)部的一個(gè)類中,過分了啊!供應(yīng)內(nèi)部類,不

是為讓你干這種事情,無聊,不讓你干。我想可能是既然靜態(tài)成員類似c語(yǔ)言的全局變量,而內(nèi)部類通常是用于創(chuàng)建內(nèi)

部對(duì)象用的,所以,把“全同變量”放在內(nèi)部類中就是富無意義的事情,既然是空無意義的事情,就應(yīng)當(dāng)被禁止),內(nèi)部

類可以干脆訪問外部類中的成員變量,內(nèi)部類可以定義在外部類的方法外面,也可以定義在外部類的方法體中,如下所

示:

publicclassOuter

(

in(out_x=0;

publicvoidmethod()

Innerlinner!=newInner!();

pubhcclassInner2〃在方法體內(nèi)部定義的內(nèi)部突

publicmethodO

ou(_x=3;

Inner2inner2=newInner2();

publicclassInnerl〃在方法體外面定義的內(nèi)部類

在方法體外面定義的內(nèi)部類的訪問類型可以是public,prolece默認(rèn)的,private等4種類型,這就似乎類中定義的成員

變量有4種訪問類型一樣,它們確定這個(gè)內(nèi)部類的定義對(duì)其他類是否可見:對(duì)于這種狀況,我們也可以在外面創(chuàng)建內(nèi)部

類的實(shí)例對(duì)象,創(chuàng)建內(nèi)部類的實(shí)例對(duì)象時(shí).,確定要先創(chuàng)建外部類的實(shí)例對(duì)象,然后用這個(gè)外部類的實(shí)例對(duì)象去創(chuàng)建內(nèi)部

類的實(shí)例對(duì)象,代碼如下:

Outerouter=newOuter();

Oulcr.lnncriinner!=oulcr.ncwInnncrl();

在方法內(nèi)部定義的內(nèi)部類前面不能有訪問類型修飾符,就似乎方法中定義的局部變量一樣,但這種內(nèi)部類的前面可

以運(yùn)用final或absiract修飾符。這種內(nèi)部類時(shí)其他類是不行見的其他類無法引用這種內(nèi)部類,但是這種內(nèi)部類創(chuàng)建的實(shí)

例對(duì)象nJ以傳遞給其他類訪問。這種內(nèi)部類必需是先定義,后運(yùn)用,即內(nèi)部類的定義代碼必需出現(xiàn)在運(yùn)用該類之前,這

與方法中的局部變量必需先定義后運(yùn)用的道理也是一樣的。這種內(nèi)部類可以訪問方法體中的局部變量,但是,該局部變

量前必需加final修飾符。

對(duì)于這些細(xì)微環(huán)節(jié),只要在eclipse寫代碼試試,依據(jù)開發(fā)工具提示的各類錯(cuò)誤信息就可以立刻了解到。

在方法體內(nèi)部還可以采納如下語(yǔ)法來創(chuàng)建一種匿名內(nèi)部類,即定義某一接口或類的子類的同時(shí),還倉(cāng)J建了該子類的

實(shí)例對(duì)象,無需為該子類定義名稱:

publicclassOuter

publicvoidstart()

newThread(

newRunable(){

publicvjidrun(){};

最終,在方法外部定義的內(nèi)部類前面可以加上sialic關(guān)鍵字,從而成為SialicNestedClass,它不再具有內(nèi)部類的特

性,全部,從狹義上講,它不是內(nèi)部類。StaticNestedClass與一般類在運(yùn)行時(shí)的行為和功能上沒有什么區(qū)分,只是在編

程引用時(shí)的語(yǔ)法上有一些差別,它可以定義成public、protecied、默認(rèn)的、private等多種類型,而一般類只能定義成public

和默認(rèn)的這兩種類型。在外面引用StaticNestedClass類的名稱為“外部類名.內(nèi)部類名”。在外面不須要僅建外部類的實(shí)

例對(duì)象,就可以干脆創(chuàng)建SiaticNestedClass,例如,假設(shè)象ner是定義在Omer類中的SialicNesiedClass,那么可以運(yùn)用

如下語(yǔ)句創(chuàng)建Inner類:

Outer.Innerinner=newOuter.Inner();

由于staticNestedClass不依靠于外部類的實(shí)例對(duì)■象,所以,staticNestedClass能訪問外部類的非static成員變量。當(dāng)

在外部類中訪問StaticNestedClass時(shí),可以干脆運(yùn)用StaticNestedClass的名字,而不須要加上外部類的名字了,在Static

NestedClass中也可以干脆引用外部類的static的成員變量,不須要加上外部類的名字。

在靜態(tài)方法中定義的內(nèi)部類也是StaticNestedClass,這時(shí)候不能在類前面加static關(guān)犍字,靜態(tài)方法中的StaticNested

Class與一般方法中的內(nèi)部類的應(yīng)用方式很相像,它除了nJ■以干脆訪問外部類中的static的成員變量,還可以訪問靜態(tài)方

法中的局部變量,但是,該局部變量前必需加final修飾符。

備注:苜先依據(jù)你的印象說出你對(duì)內(nèi)部類的總體方面的特點(diǎn):例如,在兩個(gè)地方可以定義,可以訪問外部類的成員

變量,不能定義靜態(tài)成員,這是大的特點(diǎn)。然后再說一些細(xì)微環(huán)節(jié)方面的學(xué)問,例如,幾種定義方式的語(yǔ)法區(qū)分,靜態(tài)

內(nèi)部類,以及匿名內(nèi)部類。

27、內(nèi)部類可以引用它的包含類的成員嗎?有沒有什么限制?

完全可以。假如不是靜態(tài)內(nèi)部類,那沒有什么限制!

假如你把靜態(tài)嵌套類當(dāng)作內(nèi)部類的一種特例,那在這種狀況下不行以訪問外部類的一般成員變量,而只能訪問外部

類中的靜態(tài)成員,例如,下面的代碼:

classOuter

(

staticintx;

staticclassInner

(

voidlcsi()

I

syso(x);

I

)

答題時(shí),也要能察言觀色,揣摩提問者的心思,明顯人家希望你說的是靜態(tài)內(nèi)部類不能訪問外部類

的成員,但你一上來就頂牛,這不好,要先順著人家,讓人家滿足,然后再說特殊狀況,讓人家驚訝。

28、AnonymousInnerClass(匿名內(nèi)部類)是否可以extends(繼承)

其它類,是否可以implements(實(shí)現(xiàn))interface(接口)?

可以繼承其他類或?qū)崿F(xiàn)其他接口。不僅是可以,而是必需!

29、super.getClass()方法調(diào)用

下面程序的輸出結(jié)果是多少?

importjava.util.Date;

publicclassTesLextendsDaLe{

publicstaticvoidmain(String[]args){

newTest().test();

}

publicvoidtest(){

System.out.printIn(super.getClass().getName());

}

)

很驚奇,結(jié)果是Test

這屬于腦筋急轉(zhuǎn)彎的題目,在一個(gè)qq群有個(gè)網(wǎng)友正好問過這人問題,我覺得挺好玩,就探討了一下,沒想

到今日還被你面到了,哈哈。

在test方法中,干脆調(diào)用getClass().getName()方法,返回的是Test類名

由于getClass()在Object類中定義成了final,子類不能覆蓋該方法,所以,在

test方法中調(diào)用getClass(i.getName()方法,其實(shí)就是在調(diào)用從父類繼承的getClass:)方法,等效

于調(diào)用super.getClass().getName()方法,所以,super.getClass().getName()方法返回的也

應(yīng)當(dāng)是Test。

假如想得到父類的名稱,應(yīng)當(dāng)月如下代碼:

getClass().getSuperClass().gelName();

30、String是最基本的數(shù)據(jù)類型嗎?

基本數(shù)據(jù)類型包括byte、int、char、long、floatdouble?boolean和shorto

java.lang.Slring類是final類型的,因此不行以繼承這個(gè)類、不能修改這個(gè)類。為了提高效率節(jié)約空

間,我們應(yīng)當(dāng)用StringBuffer類

31、Strings=HHeIloH;s=s+nworld!”;這兩行代碼執(zhí)行后,原始的

String對(duì)象中的內(nèi)容究竟變了沒有?

沒有。因?yàn)镾iring被設(shè)計(jì)成不行變(immutable)類,所以它的全部對(duì)象都是不行變對(duì)象。在這段代碼

中,s原先指向一個(gè)String對(duì)象,內(nèi)容是"Hello",然后我僅對(duì)s進(jìn)行了+操作,那么s所指向的那個(gè)對(duì)

象是否發(fā)生了變更呢?答案是沒有。這時(shí),s不指向原來那人對(duì)象了,而指向了另一個(gè)Suing對(duì)象,內(nèi)

容為“Hell。world!”,原來那個(gè)對(duì)象還存在于內(nèi)存之中,只是s這個(gè)引用變量不再指向它了,

通過上面的說明,我們很簡(jiǎn)潔導(dǎo)出另一個(gè)結(jié)論,假如常常對(duì)字符串進(jìn)行各種各樣的修改,或者說,

不行預(yù)見的修改,那么運(yùn)川String來代表字符串的話會(huì)引起很大的內(nèi)存開銷。因?yàn)镾tring對(duì)象建立之

后不能再變更,所以對(duì)于每一個(gè)不同的字符串,都須要一個(gè)String對(duì)象來表示。這時(shí),應(yīng)當(dāng)考慮運(yùn)用

StringBuffer類,它允許修改,而不是每個(gè)不同的字符串都要生成一個(gè)新的對(duì)象。并且,這兩種類的對(duì)

象轉(zhuǎn)換特別簡(jiǎn)潔。

同時(shí),我們還可以知道,假如要運(yùn)用內(nèi)容相同的字符串,不必每次都new一個(gè)String。例如我們要在構(gòu)

造器中對(duì)一個(gè)名叫s的String引用變量進(jìn)行初始化,把它設(shè)置為初始值,應(yīng)當(dāng)這樣做:

publicclassDemo{

privateStrings;

publicDemo{

s="Initial

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論