java基礎(chǔ)方面面試題初步_第1頁
java基礎(chǔ)方面面試題初步_第2頁
java基礎(chǔ)方面面試題初步_第3頁
java基礎(chǔ)方面面試題初步_第4頁
java基礎(chǔ)方面面試題初步_第5頁
免費預(yù)覽已結(jié)束,剩余278頁可下載查看

下載本文檔

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

文檔簡介

1、Java 基礎(chǔ)方面1、作用域 public,private,protected,以及不寫時的區(qū)別答: 區(qū)別如下:同一 package其他 package作用域 public protected friendlyprivate當(dāng)前類子孫類不寫時默認為 friendly2、Anonymous Inner Class (類) 是否可以 extends(繼承)其它類,是否可以 implements(實現(xiàn))erface(接口)類。不能 extends(繼承) 其它類,但一個類實現(xiàn)答: 的類是沒有名字的類可以作為一個接口,由另一個3、Sic Nested Class 和 Inner Class 的不同答:

2、 Nested Class ( 一般是 C+的說法), Inner Class (一般是 JAVA 的說法)。Java類與 C+嵌套類最大的不同就在于是否有指向外部的上。注: 靜態(tài)內(nèi)部類( Inner Class) 意味著 1 創(chuàng)建一個 sic類的對象, 不需要一個外部類對一個外部類對象象, 2 不能從一個 s4、&和&的區(qū)別ic類的一個對象答: &是位運算符,表示按位與運算,&是邏輯運算符, 表示邏輯與( and)5、Collection 和 Collections 的區(qū)別答: Collection 是集合類的接口,繼承與他的接口主要有 Set 和 List.Collections 是針對集

3、合類的一個幫助類,他提供一系列靜態(tài)方法實現(xiàn)對各種集合的搜索、排序、線程安全化等操作6、什么時候用 assert答:assertion(斷言)在開發(fā)中是一種常用的調(diào)試方式,很多開發(fā)語言中都支持這種機制。在實現(xiàn)中, assertion 就是在程序中的一條語句,它對一個表達式表達式的值為 true;如果該值為 false,進行檢查,一個正確程序必須保證這個說明程序已經(jīng)處于不正確的狀態(tài)下,系統(tǒng)將給出警告或退出。一般來說,assertion 用于保證程序最基本、關(guān)鍵的正確性。assertion 檢查通常在開發(fā)和測試時開啟。為了提高性能,在 發(fā)布后, assertion 檢查通常是關(guān)閉的7、String

4、s = new String(xyz);創(chuàng)建了幾個 String Object答: 兩個, 一個字符對象, 一個字符對象對象8、Math.round(11.5)等於多少? Math.round(-11.5)等於多少答: Math.round(11.5)=12;Math.round(-11.5)=-11;round 方法返回與參數(shù)最接近的長整數(shù),參數(shù)加 1/2 后求其 floor9、short s1 = 1; s1 = s1 + 1;錯? short s1 = 1; s1 += 1;錯答: short s1 = 1; s1 = s1 + 1; ( s1+1 運算結(jié)果是short s1 = 1;

5、s1 += 1;(可以正確編譯) 10、Java 有沒有 goto答: java 中的保留字, 現(xiàn)在沒有在 java 中使用11、數(shù)組有沒有 length()這個方法? String 有沒有 length()這個方法答: 數(shù)組沒有 length()這個方法,有 length 的屬性。String 有 length()這個方法型,需要強制轉(zhuǎn)換類型) 12、Overload 和 Override 的區(qū)別。Overloaded 的方法是否可以改變返回值的類型答: 方法的重寫 Overriding 和重載 Overloading 是 Java 多態(tài)性的不同表現(xiàn)。重寫Overriding 是父類與子類之

6、間多態(tài)性的一種表現(xiàn),重載 Overloading 是一個類中多態(tài)性的一種表現(xiàn)。如 果在子類中定義某方法與其父類有相同的名稱和參數(shù), 說該方法被重寫 (Overriding)。子類的對象使用這個方法時,將調(diào)用子類中的定義,對它 而言,父類中的定義如同被了。如果在一個類中定義了多個同名的方法, 它們或有不同的參數(shù)個數(shù)或有不同的參數(shù)類型,則稱為方法的重載 (Overloading)。 Overloaded 的方法是可以改變返回值的類型13、Set 里的元素是不能重復(fù)的, 那么用什么方法來區(qū)分重復(fù)與否呢? 是用=還是equals()? 它們有何區(qū)別答: Set 里的元素是不能重復(fù)的, 那么用 iter

7、ator()方法來區(qū)分重復(fù)與否。equals()是判讀兩個 Set 是否相等equals()和=方法決定值是否指向同一對象 equals()在類中被覆蓋, 為的是當(dāng)兩個分離的對象的內(nèi)容和類型相配的話,返回真值14、給我一個你最常見到的 runtime exception答: 常 見的運行時異常有如下這些ArithmeticException, ArrayStoreException, BufferOverflowException, Buffe rUnderflowException, CannotRedoException, CannotUndoException, ClassCastExc

8、eption, CMMException,currentModificationException, DOMException,EmptyStackException, IllegalArgumentException, IllegalMonitorSeException, IllegalPathSeException, IllegalSeException, ImagingOpException, IndexOutOfBoundsException, MissingResourceException, NegativeArraySizeException, NoSuchElementExce

9、ption, NullPoerException, ProfileDataException, ProviderException, RasterFormatException, SecurityException, S ystemException, UndeclaredThrowableException, UnmodifiableSetException,UnsupportedOperationException15、error 和 exception區(qū)別答: error 表示恢復(fù)不是不可能但很不可能指望程序能處理這樣的情況exception 表示一種設(shè)計或?qū)崿F(xiàn)問題。也就是說,它表示如果

10、程序運行正常,從不會發(fā)生的情況16、List, Set, Map 是否繼承自 Collection 接口答: List, Set 是, Map 不是的情況下的一種嚴重問題。比如說內(nèi)存溢出。17、abstract class 和erface區(qū)別方法的存在而不去實現(xiàn)它的類被叫做抽象類( abstract class),它用于要創(chuàng)答: 建一現(xiàn)某些基本行為的類,并為該類方法,但不能在該類中實現(xiàn)該類的情況。不能創(chuàng)建 abstract 類的實例。然而可以創(chuàng)建一個變量,其類型是一個抽象類,并讓它指向具體子類的一個實例。不能有抽象構(gòu)造函數(shù)或抽象靜態(tài)方法。Abstract 類的子類為它們父類中的所有抽象方法提供

11、實現(xiàn),否則它們也是抽象類為。取而代之,在子類中實現(xiàn)該方法。知道其行為的其它類可以在類中實現(xiàn)這些方法接口(erface) 是抽象類的變體。在接口中, 所有方法都是抽象的。多繼承性可通過實現(xiàn)這樣的接口而獲得。接口中的所有方法都是抽象的,沒有一個有程序體。接口只可以定義 sic final 成 員變量。接口的實現(xiàn)與子類相似,除了該實現(xiàn)類不能從接口定義中繼承行為。當(dāng)類實現(xiàn)特殊接口時,它定義(即將程序體給予)所有這種接口的方法。然后,它可以 在實現(xiàn)了該接口的類的任何對象上調(diào)用接口的方法。由于有抽象類,它允許使用接口名作為變量的類型。通常的動態(tài)聯(lián)編將生效??梢赞D(zhuǎn)換到接口類型或從 接口類型轉(zhuǎn)換, insta

12、nceof 運算符可以用來決定某對象的類是否實現(xiàn)了接口18、abstract 的 method 是否可同時是 s時是 synchronizedic,是否可同時是 native, 是否可同答: 都不能19、接口是否可繼承接口? 抽象類是否可實現(xiàn)(implements)接口? 抽象類是否可繼承實體類(crete class)答:接口可以繼承接口。抽象類可以實現(xiàn)(implements)接口,抽象類是否可繼承實體類,但前提是實體類必須有明確的構(gòu)造函數(shù)20、構(gòu)造器答: 構(gòu)造器Overloadingstructor 是否可被 overridestructor 不能被繼承, 因此不能重寫 Overridin

13、g,但可以被重載21、是否可以繼承 String 類答: String 類是 final 類故不可以繼承22、try 里有一個 return 語句,那么緊跟在這個 try 后的 finally 里的 code會不會被執(zhí)行, 什么時候被執(zhí)行, 在 return 前還是后答: 會執(zhí)行, 在 return 前執(zhí)行23、用最有效率的方法算出 2 乘以 8 等於幾答: 2 0) y 會增長,If(x=33 & +y0)不會增長&還可以用作位運算符,當(dāng)&操作符兩邊的表達式不是 類型時,&表示按位與操作, 通常使用 0 x0f 來與一個整數(shù)進行&運算,來獲取該整數(shù)的最低 4個 bit 位,例如,031& 0

14、 x0f 的結(jié)果為 001。備注:這道題先說兩者的共同點,再說出&和&的特殊之處,并列舉一些經(jīng)典的例子來表明自己理解透徹深入、實際經(jīng)驗豐富。4、在 JAVA 中如何跳出當(dāng)前的多重嵌套循環(huán)?在 Java 中,要想跳出多重循環(huán),可以在外面的循環(huán)語句前定義一個標號,然后在里層循環(huán)體的代碼中使用帶有標號的 break 語句,即可跳出外層循環(huán)。例如,ok:for(i=0;i10;i+) for(j=0;j10;j+) System.out.prln(“i=” + i+ “,j=” + j);if(j = 5) break ok;另外,我個人通常并不使用標號這種方式,而是讓外層的循環(huán)條件表達式的結(jié)果可以受

15、到里層循環(huán)體代碼的控制,例如,要在二維數(shù)組中查找到某個數(shù)字。arr =1,2,3,4,5,6,7,9;found =false;for(i=0;ifor(j=0;jarri.length;j+)/arri.length;j+)System.out.prln(“i=” + i+ “,j=” + j);if(arrij = 5) found = true;break;5、switch 語句能否作用在 byte 上,能否作用在 long 上,能否作用在 String 上?在 switch(expr1)中,expr1 只能是一個整數(shù)表達式或者枚舉常量(更大字體),整數(shù)表達式可以是基本類型或eger 包

16、裝類型,由于,byte,short,char 都可以隱含轉(zhuǎn)換為,所以,這些類型以及這些類型的包裝類型也是可以的。顯然,long 和String 類型都不符合switch 的語所以,它們不能作用于 swtich 語句中。定,并且不能被隱式轉(zhuǎn)換成類型,6、short s1 = 1; s1 = s1+ 1;錯? short s1 = 1; s1 += 1;錯?對于 shorts1 = 1; s1 = s1 + 1; 由于 s1+1 運算時會自動表達式的類型,所需要強制轉(zhuǎn)換類型的以結(jié)果是錯誤。型,再賦值給 short 類型 s1 時,編譯器將對于 shorts1 = 1; s1 += 1;由于 +=

17、是 java 語言規(guī)定的運算符,java 編譯器會對它進行特殊處理,因此可以正確編譯。7、char 型變量中能不能存貯一個中文漢字?為什么?char 型變量是用來Unicode 編碼的字符的,unicode 編碼字符集中包含了漢字,所以,char 型變量中當(dāng)然可以漢字啦。不過,如果某個特殊的漢字沒有被包含在 unicode 編碼字符集中,那么,這個 char 型變量中就不能這個特殊漢字。補充說明:unicode 編碼占用兩個字節(jié),所以,char 類型的變量也是占用兩個字節(jié)。備注:后面一部分回答雖然不是在正面回答題目,但是,為了展現(xiàn)自己的學(xué)識和表現(xiàn)自己對問題理解的透徹深入,可以回答一些相關(guān)的知識

18、,做到知無不言,言無不盡。8、用最有效率的方法算出 2 乘以 8 等於幾?2 3,因為將一個數(shù)n 位,就相當(dāng)于乘以了 2 的 n 次方,那么,一個數(shù)乘以 8 只要將其3 位即可,而位運算 cpu 直接支持的,效率最高,所以,2 乘以 8等於幾的最效率的方法是 2 3。9、請設(shè)計一個一百億的計算器首先要明白這道題目的考查點是什么,一是大家首先要對計算機原理的底層細節(jié)要清楚、要知道加減法的位運算原理和知道計算機中的算術(shù)運算會發(fā)生越界的情況,二是要具備一定的面象的設(shè)計。首先,計算機中用固定數(shù)量的幾個字節(jié)來數(shù)值是有一定的范圍的,為了便于講解和理解的數(shù)值,所以計算機中能夠表示的先以 byte 類型的整數(shù)

19、為例,它用 1 個字節(jié)進行,表示的最大數(shù)值范圍為-128 到+127。-1 在內(nèi)存中對應(yīng)的二進制數(shù)據(jù)為 11111111,如果兩個-1 相加,不考慮 Java 運算時的類型,運算后會產(chǎn)生進位,二進制結(jié)果為 1,11111110,由于進位后超過了 byte 類型的空間,所以進位部分被舍棄,即最終的結(jié)果為 11111110,也就是-2,這正好利用溢位的方式實現(xiàn)了負數(shù)的運算。-128 在內(nèi)存中對應(yīng)的二進制數(shù)據(jù)為10000000,如果兩個-128 相加,不考慮 Java 運算時的類型,運算后會產(chǎn)生進位,二進制結(jié)果為 1,00000000,由于進位后超過了 byte 類型的空間,所以進位部分被舍棄,即最

20、終的結(jié)果為 00000000,也就是 0,這樣的結(jié)果顯然不是期望的,這說明計算機中的算術(shù)運算是會發(fā)生越界情況的,兩個數(shù)值的運算結(jié)果時的類型自動過計算機中的該類型的數(shù)值范圍。由于 Java 中涉及表達式運算,無法用 byte 類型來做演示這種問題和現(xiàn)象的實驗,大家可以用下面一個使用整數(shù)做實驗的例子程序體驗一下:a =eger.MAX_VALUE;b =eger.MAX_VALUE;sum = a + b;System.out.prln(“a=”+a+”,b=”+b+”,sum=”+sum);先不考慮 long 類型,由于的正數(shù)范圍為 2 的 31 次方,表示的最大數(shù)值約等于 2*1000*100

21、0*1000,也就是 20 億的大小,所以,要實現(xiàn)一個一百億的計算器,得自己設(shè)計一個類可以用于表示很大的整數(shù),并且提供了與另外一個整數(shù)進行加減乘除的功能,大概功能如下:()這個類二進制數(shù)有兩個成員變量,一個表示符號,另一個用字節(jié)數(shù)組表示數(shù)值的()有一個構(gòu)造方法,把一個包含有多位數(shù)值的字符串轉(zhuǎn)換到數(shù)組中的符號和字節(jié)()提供加減乘除的功能public classBigegersign;byte val;public Bigeger(String val) sign = ;val = ;public Bigeger add(Bigegerother) public Bigeger subtract(

22、Bigegerother) public Bigeger multiply(Bigegerother)public Bigeger divide(Bigegerother)備注:要想寫出這個類的完整代碼,是非常復(fù)雜的,如果有的話,可以參看jdk 中自帶的 java.math.Bigeger 類的源碼。面試的人也知道誰都不可能在短時間內(nèi)寫出這個類的完整代碼的,他要的是你是否有這方面的概念和意識,他最重要的還是考查你的能力,所以,你不要因為自己無法寫出完整的最終結(jié)果就放棄答這道題,你要做的就是你比別人寫得多,證明你比別人強,你有這方面的思想意識就可以了,畢竟別人可能連題目的意思都看不懂,什么都沒寫

23、,你要敢于答這道題,即使只答了一部分,那也與那些什么都不懂的人區(qū)別出來,拉開了距離,算是矮子中的高個,機會當(dāng)然就屬于你了。另外,中的框架代碼也很重要,體現(xiàn)了一些面象設(shè)計的功底,特別是其中的方法命名很專業(yè),用的英文單詞很精準,這也是能力、經(jīng)驗、專業(yè)性、英語水多個方面的體現(xiàn),會給人留下很好的印象,在編程能力和其他方面條件差不多的情況下,英語好除了可以使你獲得機會外,薪水可以高出一千元。10、使用 final 關(guān)鍵字修飾一個變量時,是使用 final 關(guān)鍵字修飾一個變量時,是指不能變,還是變量不能變,的對象不能變?變量所指向的對象中的內(nèi)容還是可以改變的。例如,對于如下語句:final StringB

24、uffer a=new StringBuffer(“immutable”);執(zhí)行如下語句將編譯期錯誤:a=new StringBuffer(“”);但是,執(zhí)行如下語句則可以通過編譯:a.append(” broken!”);有人在定義方法的參數(shù)時,可能想采用如下形式來數(shù)對象:方法修改傳進來的參public void method(final StringBuffaram)實際上,這是辦不到的,在該方法仍然可以增加如下代碼來修改參數(shù)對象:param.append(“a”);11、”=”和 equals 方法究竟區(qū)別?(單獨把一個東西說清楚,然后再說清楚另一個,這樣,它們的區(qū)別自然就出來了,混在一

25、起說,則很難說清楚)=操作符專門用來比較兩個變量的值是否相等,也就是用于比較變量所對應(yīng)的內(nèi)存中所的數(shù)值是否相同,要比較兩個基本類型的數(shù)據(jù)或兩個變量是否相等,只能用=操作符。如果一個變量指向的數(shù)據(jù)是對象類型的,那么,這時候涉及了兩塊內(nèi)存,對象本身占用一塊內(nèi)存(堆內(nèi)存),變量也占用一塊內(nèi)存,例如 Objet obj = new Object();變量 obj 是一個內(nèi)存,new Object()是另一個內(nèi)存,此時,變量 obj 所對應(yīng)的內(nèi)存中的數(shù)值就是對象占用的那塊內(nèi)存的首地址。對于指象類型的變量,如果要比較兩個變量是否指向同一個對象,即要看這兩個變量所對應(yīng)的內(nèi)存中的數(shù)值是否相等,這時候就需要用=

26、操作符進行比較。equals 方法是用于比較兩個獨立對象的內(nèi)容是否相同,就好比去比較兩個人的長相是否相同,它比較的兩個對象是獨立的。例如,對于下面的代碼:String a=new String(“foo”);String b=new String(“foo”);兩條 new 語句創(chuàng)建了兩個對象,然后用 a,b 這兩個變量分別指向了其中一個對象,這是兩個不同的對象,它們的首地址是不同的,即 a 和 b 中的數(shù)值是不相同的,所以,表達式 a=b 將返回 false,而這兩個對象中的內(nèi)容是相同的,所以,表達式 a.equals(b)將返回 true。在實際開發(fā)中,經(jīng)常要比較傳遞進行來的字符串內(nèi)容是否

27、等,例如,Stringinput = ;input.equals(“quit”),許多人稍不注意就使用=進行比較了,這是錯誤的,隨便從網(wǎng)上找?guī)讉€項目實戰(zhàn)的教學(xué)看看,里面就有大量這樣的錯誤。記住,字符串的比較基本上都是使用 equals 方法。如果一個類沒有自己定義 equals 方法,那么它將繼承 Object 類的equals 方法,Object 類的 equals 方法的實現(xiàn)代碼如下:equals(Object o)return this=o;這說明,如果一個類沒有自己定義 equals 方法,它默認的 equals 方法(從 Object類繼承的)就是使用=操作符,也是在比較兩個變量指向

28、的對象是否是同一對象,這時候使用 equals 和使用=會得到同樣的結(jié)果,如果比較的是兩個獨立的對象則總返回 false。如果你編寫的類希望能夠比較該類創(chuàng)建的兩個實例對象的內(nèi)容是否相同,那么你必須覆蓋 equals 方法,由你自己寫代碼來決定在什么情況即可認為兩個對象的內(nèi)容是相同的。12、靜態(tài)變量和實例變量的區(qū)別?在語法定義上的區(qū)別:靜態(tài)變量前要加 sic 關(guān)鍵字,而實例變量前則不加。在程序運行時的區(qū)別:實例變量屬于某個對象的屬性,必須創(chuàng)建了實例對象,其中的實例變量才會被分配空間,才能使用這個實例變量。靜態(tài)變量不屬于某個實例對象,而是屬于類,所以也稱為類變量,只要程序加載了類的字節(jié)碼,不用創(chuàng)建

29、任何實例對象,靜態(tài)變量就會被分配空間,靜態(tài)變量就可以被使用了。總之,實例變量必須創(chuàng)建對象后才可以通過這個對象來使用,靜態(tài)變量則可以直接使用類名來。例如,對于下面的程序,無論創(chuàng)建多少個實例對象都只分配了一個sicVar變量,并且每創(chuàng)建一個實例對象,這個 sicVar 就會加 1;但是,每創(chuàng)建一個實例對象,就會分配一個 instanceVar,即可能分配多個 instanceVar,并且每個instanceVar 的值都只自加了 1 次。public class VariantTestpublicsicsicVar = 0;publicinstanceVar = 0;publicVariantTe

30、st()sicVar+;instanceVar+;System.out.prln(“sicVar=”+ sicVar + ”,instanceVar=” + instanceVar);備注:這個解答除了說清楚兩者的區(qū)別外 ,最后還用一個具體的應(yīng)用例子來說明兩者的差異,體現(xiàn)了自己有很好的解說問題和設(shè)計案例的能力,思維敏捷,超過一般程序員,有寫作能力!13、是否可以從一個 sic 方法發(fā)出對非 sic 方法的調(diào)用?不可以。因為非 sic 方法是要與對象關(guān)聯(lián)在一起的,必須創(chuàng)建一個對象后,才可以在該對象上進行方法調(diào)用,而 sic 方法調(diào)用時不需要創(chuàng)建對象,可以直接調(diào)用。也就是說,當(dāng)一個 sic 方法被

31、調(diào)用時,可能還沒有創(chuàng)建任何實例對象,如果從一個 sic 方法中發(fā)出對非 sic 方法的調(diào)用,那個非 sic 方法是關(guān)聯(lián)到哪個對象上的呢?這個邏輯無法成立,所以,一個 sic 方法發(fā)出對非sic 方法的調(diào)用。14、eger 與的區(qū)別是 java 提供的 8 種原始數(shù)據(jù)類型之一。Java 為每個原始類型提供了封裝類,eger 是 java 為提供的封裝類。的默認值為 0,而eger 的默認值為null,即eger 可以區(qū)分出未賦值和值為 0 的區(qū)別,則無法表達出未賦值的情況,例如,要想表達出沒有參加和成績?yōu)? 的區(qū)別,則只能使用eger。在 JSP 開發(fā)中,為空白字符串,而結(jié)果為 0,所以,ege

32、r 的默認為 null,所以用 el 表達式在文本框中顯示時,值默認的默認值為 0,所以用 el 表達式在文本框中顯示時,不適合作為 web 層的表單數(shù)據(jù)的類型。在 Hibernate 中,如果將 OID 定義為eger 類型,那么 Hibernate 就可以根據(jù)其值是否為 null 而判斷一個對象是否是臨時的,如果將 OID 定義為了類型,還需要在 hbm文件中設(shè)置其 unsaved-value 屬性為 0。另外,整數(shù),eger 提供了多個與整數(shù)相關(guān)的操作方法,例如,將一個字符串轉(zhuǎn)換成eger 中還定義了表示整數(shù)的最大值和最小值的常量。15、Math.round(11.5)等於多少? Mat

33、h.round(-11.5)等於多少?Math 類中提供了三個與取整有關(guān)的方法:ceil、floor、round,這些方法的作用與它們的英文名稱的含義相對應(yīng),例如,ceil 的英文意義是天花板,該方法就表示向上取整,Math.ceil(11.3)的結(jié)果為 12,Math.ceil(-11.3)的結(jié)果是-11;floor 的英文意義是地板,該方法就表示向下取整,Math.floor(11.6)的結(jié)果為11,Math.floor(-11.6)的結(jié)果是-12;最難掌握的是 round 方法,它表示“四舍五入”,算法為 Math.floor(x+0.5),即將原來的數(shù)字加上 0.5 后再向下取整,所以

34、,Math.round(11.5)的結(jié)果為 12,Math.round(-11.5)的結(jié)果為-11。16、下面的代碼不妥之處?1.if(username.equals(“zxx”)2.x = 1;return x=1?true:false;17、請說出作用域 public,private,protected,以及不寫時的區(qū)別這四個作用域的可見范圍如下表所示。說明:如果在修飾的元素上面沒有寫任何修飾符,則表示 friendly。作用域 當(dāng)前類同一 package 子孫類其他 packagepublic protected friendly private 備注:只要記住了有 4 種權(quán)限,4 個范

35、圍,然后將全選和范圍在水平和垂直方向上分別按排從小到大或從大到小的順序排列,就很容易畫出上面的圖了。18、Overload 和 Override 的區(qū)別。Overloaded 的方法是否可以改變返回值的類型?Overload 是重載的意思,Override 是覆蓋的意思,也就是重寫。重載 Overload 表示同一個類中可以有多個名稱相同的方法,但這些方法的參數(shù)列表各不相同(即參數(shù)個數(shù)或類型不同)。重寫 Override 表示子類中的方法可以與父類中的某個方法的名稱和參數(shù)完全相同,通過子類創(chuàng)建的實例對象調(diào)用這個方法時,將調(diào)用子類中的定義方法,這相當(dāng)于把父類中定義的那個完全相同的方法給覆蓋了,這

36、也是面 象編程的多態(tài)性的一種表現(xiàn)。子類覆蓋父類的方法時,只能比父類拋出更少的異常,或者是拋出父類拋出的異常的子異常,因為子類可以解決父類的一些問題,不能比父類有。子類方法的 權(quán)限只能比父類的更大,不能更小。如果父類的方法是 private 類型,那么,子類則不存在覆蓋的限制,相當(dāng)于子類中增加了一個全新的方法。至于 Overloaded 的方法是否可以改變返回值的類型這個問題,要看你倒底想問什么呢?這個題目很模糊。如果幾個 Overloaded 的方法的參數(shù)列表不一樣,它們的返回者類型當(dāng)然也可以不一樣。但我估計你想問是:如果兩個方法的參數(shù)列表完全一樣,是否可以讓它們的返回值不同來實現(xiàn)重載 Ove

37、rload。這是的,可以用反證法來說明這個問題,因為有時候調(diào)用一個方法時也可以不定義返回結(jié)果變量,即不要關(guān)心其返回結(jié)果,例如,調(diào)用map.remove(key)方法時,雖然 remove 方法有返回值,但是通常都不會定義接收返回結(jié)果的變量,這時候假設(shè)該類中有兩個名稱和參數(shù)列表完全相同的方法,僅僅是返回類型不同,java 就無法確定編程者倒底是想調(diào)用哪個方法了,因為它無法通過返回結(jié)果類型來判斷。override 可以翻譯為覆蓋,從字面就可以知道,它是覆蓋了一個方法并且對其重寫,以求達到不同的作用。對接口中一般只是對方法進行了來說最熟悉的覆蓋就是對接口方法的實現(xiàn),在,而在實現(xiàn)時,就需要實現(xiàn)接口的所

38、有方法。除了這個典型的用法以外,方法。在覆蓋要注意以下的幾點:在繼承中也可能會在子類覆蓋父類中的1、覆蓋的方法的標志必須要和被覆蓋的方法的標志完全匹配,才能達到覆蓋的效果;2、覆蓋的方法的返回值必須和被覆蓋的方法的返回一致;3、覆蓋的方法所拋出的異常必須和被覆蓋方法的所拋出的異常一致,或者是其子類;4、被覆蓋的方法不能為 private,否則在其子類中只是新定義了一個方法,并沒有對其進行覆蓋。overload 對來說可能比較熟悉,可以翻譯為重載,它是指可以定義一些名稱相同的方法,通過定義不同的輸入?yún)?shù)來區(qū)分這些方法,然后再調(diào)用時,JVM就會根據(jù)不同的參數(shù)樣式,來選擇合適的方法執(zhí)行。在使用重載要

39、注意以下的幾點:1、在使用重載時只能通過不同的參數(shù)樣式。例如,不同的參數(shù)類型,不同的參數(shù)個數(shù),不同的參數(shù)順序(當(dāng)然,同一方法內(nèi)的幾個參數(shù)類型必須不一樣,例如可以是 fun(,float),但是不能為 fun(,));2、不能通過權(quán)限、返回類型、拋出的異常進行重載;3、方法的異常類型和數(shù)目不會對重載造成影響;4、對于繼承來說,如果某一方法在父類中是權(quán)限是 priavte,那么就不能在子類對其進行重載,如果定義的話,也只是定義了一個新方法,而不會達到重載的效果。19、構(gòu)造器structor 是否可被 override?構(gòu)造器structor 不能被繼承,因此不能重寫Override,但可以被重載O

40、verload。20、接口是否可繼承接口? 抽象類是否可實現(xiàn)(implements)接口? 抽象類是否可繼承具體類(crete class)? 抽象類中是否可以有靜態(tài)的 main 方法?接口可以繼承接口。抽象類可以實現(xiàn)(implements)接口,抽象類是否可繼承具體類。抽象類中可以有靜態(tài)的 main 方法。備注:只要明白了接口和抽象類的本質(zhì)和作用,這些問題都很好回答,你想想,如果你是 java 語言的設(shè)計者,你是否會提供這樣的支持,如果不提供的話,有什么理由嗎?如果你沒有道理不提供,那就是肯定的了。只有記住抽象類與普通類的唯一區(qū)別就是不能創(chuàng)建實例對象和允許有 abstract方法。21、寫

41、clone()方法時,通常都有一行代碼,是什么?clone 有缺省行為,super.clone();因為首先要把父類中的成員到位,然后才是自己的成員。22、面計算機象的特征有哪些方面系統(tǒng)是現(xiàn)實生活中的業(yè)務(wù)在計算機中的,而現(xiàn)實生活中的業(yè)務(wù)其實就是一個個對象協(xié)作的過程。面象編程就是按現(xiàn)實業(yè)務(wù)一樣的方式將程序代碼按一個個對象進行組織和編寫,讓計算機系統(tǒng)能夠識別和理解用對象方式組織和編寫的程序代碼,這樣就可以把現(xiàn)實生活中的業(yè)務(wù)對象到計算機系統(tǒng)中。面象的編程語言有封裝、繼承、抽象、多態(tài)等 4 個主要的特征。1 封裝:封裝是保證具有優(yōu)良的模塊性的基礎(chǔ),封裝的目標就是要實現(xiàn)的“高內(nèi)聚、低耦合”,防止程序相互

42、依賴性而帶來的變動影響。在面象的編程語言中,對象是封裝的最基本,面象的封裝比傳統(tǒng)語言的封裝更為清晰、更為有力。面象的封裝就是把描述一個對象的屬性和行為的代碼封裝在一個“模塊”中,也就是一個類中,屬性用變量定義,行為用方法進行定義,方法可以直接同一個對象中的屬性。通常情況下,只要記住讓變量和這個變量的方法放在一起,將一個類中的成員變量全部定義成私有的,只有這個類自己的方法才可以到這些成員變量,這就基本上實現(xiàn)對象的封裝,就很容易找出要分配到這個類上的方法了,就基本上算是會面象的編程了。把握一個原則:把對同一事物進行操作的方法和相關(guān)的方法放在同一個類中,把方法和它操作的數(shù)據(jù)放在同一個類中。例如,人要

43、在黑板上畫圓,這一共涉及三個對象:人、黑板、圓,畫圓的方法要分配給哪個對象呢?由于畫圓需要使用到圓心和半徑,圓心和半徑顯然是圓的屬性,如果將它們在類中定義成了私有的成員變量,那么,畫圓的方法必須分配給圓,它才能到圓心和半徑這兩個屬性,人以后只是調(diào)用圓的畫圓方法、表示給圓發(fā)給消息而已,畫圓這個方法不應(yīng)該分配在人這個對象上,這就是面象的封裝性,即將對象封裝成一個高度自治和相對封閉的,對象狀態(tài)(屬性)由這個對象自己的行為(方法)來和改變。一個更便于理解的例子就是,司機將火車剎住了,剎車的動作是分配給,還是分配給火車,顯然,應(yīng)該分配給火車,因為自身是不可能有那么大的力氣將一個火車給停下來的,只有火車自

44、己才能完成這一動作,火車需要調(diào)用的離合器和剎車片等多個器件協(xié)作才能完成剎車這個動作,執(zhí)行剎車動作而已。剎車的過程只是給火車發(fā)了一個消息,通知火車要抽象:抽象就是找出一些事物的相似和共性之處,然后將這些事物歸為一個類,這個類只考慮這些事物的相似和共性之處,并且會忽略與當(dāng)前和目標無關(guān)的那些方面,將注意力集中在與當(dāng)前目標有關(guān)的方面。例如,看到一只螞蟻和大象,你能夠想象出它們的相同之處,那就是抽象。抽象包括行為抽象和狀態(tài)抽象兩個方面。例如,定義一個類,如下:classString name;age;人本來是很復(fù)雜的事物,有很多方面,但因為當(dāng)前系統(tǒng)只需要了解人的和年齡,所以上面定義的類中只包含和這兩個屬

45、性,這就是一種抽像,使用抽象可以避免考慮一些與目標無關(guān)的細節(jié)。我對抽象的理解就是不要用顯微鏡去看一個事物的所有方面,這樣涉及的內(nèi)容就太多了當(dāng)前系統(tǒng)需要什么,就只考慮什么。劃分問題的邊界,繼承:在定義一個類的時候,可以在一個已經(jīng)存在的類的基礎(chǔ)之上來進行,把這個已經(jīng)存在的類所定義的內(nèi)容作為自己的內(nèi)容,并可以加入若干新的內(nèi)容,或修改原來的方法使之更適合特殊的需要,這就是繼承。繼承是子類自動共享父類數(shù)據(jù)和方法的機制,這是類之間的一種關(guān)系,提高了的可重用性和可擴展性。多態(tài):多態(tài)是指程序中定義的變量所指向的具體類型和通過該變量發(fā)出的方變量倒底會法調(diào)用在編程時并不確定,而是在程序運行期間才確定,即一個指向哪

46、個類的實例對象,該變量發(fā)出的方法調(diào)用到底是哪個類中實現(xiàn)的方法,必須在由程序運行期間才能決定。因為在程序運行時才確定具體的類,這樣,不用修改源程序代碼,就可以讓變量綁定到各種不同的類實現(xiàn)上,從而導(dǎo)致該調(diào)用的具體方法隨之改變,即不修改程序代碼就可以改變程序運行時所綁定的具體代碼,讓程序可以選擇多個運行狀態(tài),這就是多態(tài)性。多態(tài)性增強了的靈活性和擴展性。例如,下面代碼中的 User是一個接口,它定義變量 user指向的實例對象由factory.get()在執(zhí)行的時候返回,有時候指向的是 UserJdbc這個實現(xiàn),有時候指向的是 UserHibernate這個實現(xiàn),這樣,不用修改源代碼,就可以改變 us

47、er指向的具體類實現(xiàn),從而導(dǎo)致 user.insertUser()方法調(diào)用的具體代碼也隨之改變,即有時候調(diào)用的是UserJdbc的 insertUser 方法,有時候調(diào)用的是 UserHibernate的insertUser 方法:Useruser=factory.get();user.insertUser(user);比喻:人吃飯,你看到的是左手,還是右手?23、java 中實現(xiàn)多態(tài)的機制是什么?靠的是父類或接口定義的變量可以指向子類或具體實現(xiàn)類的實例對象,而程序調(diào)用的方法在運行期才動態(tài)綁定,就是變量所指向的具體實例對象的方法,也就是內(nèi)存里正在運行的那個對象的方法,而不是變量的類型中定義的方

48、法。24、abstract class 和erface區(qū)別?含有 abstract 修飾符的 class 即為抽象類,abstract 類不能創(chuàng)建的實例對象。含有 abstract 方法的類必須定義為 abstract class,abstract class 類中的方法不必是抽象的。abstract class 類中定義抽象方法必須在具體(crete)子類中實現(xiàn),所以,不能有抽象構(gòu)造方法或抽象靜態(tài)方法。如果的子類沒有實現(xiàn)抽象父類中的所有抽象方法,那么子類也必須定義為 abstract 類型。接口(erface)可以說成是抽象類的一種特例,接口中的所有方法都必須是抽象的。接口中的方法定義默認為

49、 public abstract 類型,接口中的成員變量類型默認為 public sic final。下面比較一下兩者的語法區(qū)別:1.抽象類可以有構(gòu)造方法,接口中不能有構(gòu)造方法。2.抽象類中可以有普通成員變量,接口中沒有普通成員變量3.抽象類中可以包含非抽象的普通方法,接口中的所有方法必須都是抽象的,不能有非抽象的普通方法。4. 抽象類中的抽象方法的類型可以是 public,protected 和(默認類型,雖然eclipse 下不報錯,但應(yīng)該也),但接口中的抽象方法只能是 public 類型的,并且默認即為 public abstract 類型。5. 抽象類中可以包含靜態(tài)方法,接口中不能包含

50、靜態(tài)方法6. 抽象類和接口中都可以包含靜態(tài)成員變量,抽象類中的靜態(tài)成員變量的類型可以任意,但接口中定義的變量只能是 public sic final 類型,并且默認即為 public sic final 類型。7.一個類可以實現(xiàn)多個接口,但只能繼承一個抽象類。下面接著再說說兩者在應(yīng)用上的區(qū)別:接口的是在系統(tǒng)架構(gòu)設(shè)計方法發(fā)揮作用,主要用于定義模塊之間的通信契約。而抽象類在代碼實現(xiàn)方面發(fā)揮作用,可以實現(xiàn)代碼的重用,例如,模板方法設(shè)計模式是抽象類的一個典型應(yīng)用,假設(shè)某個項目的所有 Servlet 類都要用相同的方式進行權(quán)限判斷、日志和處理異常,那么就可以定義一個抽象的基類,讓所有的 Servlet

51、都繼承這個抽象基類,在抽象基類的 service 方法中完成權(quán)限判斷、日志和處理異常的代碼,在各個子類中只是完成各自的業(yè)務(wù)邏輯代碼,偽代碼如下:public abstract class BaseServlet extendsHttpServletpublicfinal void service(HttpServletRequest request, HttpServletResponseresponse)throws IOExcetion,ServletException 日志進行權(quán)限判斷if(具限)trydoService(request,response);catch(Excetpion

52、 e) 異常信息protectedabstract void doService(HttpServletRequest request,HttpServletResponseresponse) throws IOExcetion,ServletException;/注意的權(quán)限定義成 protected,顯得既專業(yè),又嚴謹,因為它是專門給子類用public class MyServlet1 extendsBaseServletprotected void doService(HttpServletRequestrequest, HttpServletResponseresponse) throw

53、s IOExcetion,ServletException本 Servlet 只處理的具體業(yè)務(wù)邏輯代碼父類方法中間的某段代碼不確定,留給子類干,就用模板方法設(shè)計模式。備注:這道題的思路是先從總體解釋抽象類和接口的基本概念,然后再比較兩者的語法細節(jié),最后再說兩者的應(yīng)用區(qū)別。比較兩者語法細節(jié)區(qū)別的條理是:先從一個類中的構(gòu)造方法、普通成員變量和方法(包括抽象方法),靜態(tài)變量和方法,繼承性等 6 個方面逐一去比較回答,接著從第三者繼承的角度的回答,特別是最后用了一個典型的例子來展現(xiàn)自己深厚的技術(shù)功底。25、abstract 的 method 是否可同時是 s是 synchronized?ic,是否可同

54、時是 native,是否可同時abstract 的 method 不可以是 sic 的,因為抽象的方法是要被子類實現(xiàn)的,而sic 與子類扯不上關(guān)系!native 方法表示該方法要用另外一種依賴的編程語言實現(xiàn)的,不存在著被子類實現(xiàn)FileOutput,所以,它也不能是抽象的,不能與 abstract 混用。例如,類要硬件打交道,底層的實現(xiàn)用的是操作系統(tǒng)相關(guān)的 api 實現(xiàn),例如,在 windows 用 c 語言實現(xiàn)的,所以,查看 jdk 的源代碼,可以發(fā)現(xiàn)FileOutputStream 的 open 方法的定義如下:private native void open(String name)th

55、rows FileNotFoundException;如果要用 java 調(diào)用別人寫的 c 語言函數(shù),是無法直接調(diào)用的,需要按照 java 的要求寫一個 c 語言的函數(shù),又的這個 c 語言函數(shù)去調(diào)用別人的 c 語言函數(shù)。由于的 c 語言函數(shù)是按 java 的要求來寫的,這個 c 語這個 c 函面言函數(shù)就可以與 java 對接上,java 那邊的對接方式就是定義出與數(shù)相對應(yīng)的方法,java 中對應(yīng)的方法不需要寫具體的代碼,但需要native。關(guān)于 synchronized 與 abstract 合用,我覺得也,因為在我?guī)啄甑膶W(xué)習(xí)和開發(fā)中,從來沒見到過這種情況,并且我覺得 synchronized

56、 應(yīng)該是作用在一個具體的方法上才有意義。而且,方法上的 synchronized 同步所使用的同步鎖對象是 this,而抽象方法上無法確定 this 是什么。26、類?Sic Nested Class 和 Inner Class 的不同。類就是在一個類的定義的類,類中不能定義靜態(tài)成員(靜態(tài)成員不是對象的特性,只是為了找一個容身之處,所以需要放到一個類中而已,這么一點小事,你還要把它放到類的一個類中,過分了?。√峁╊?,不是為讓你干這種事情,無聊,不讓你干。可能是既然靜態(tài)成員類似 c 語言的全局變量,而類通常是用于創(chuàng)建對象用的,所以,把“全局變量”放在類中就是毫無意義的事情,既然是毫無意義的事情,

57、就應(yīng)該被),類可以直接外部類中的成員變量,類可以定義在外部類的方法外面,也可以定義在外部類的方法體中,如下所示:public class Outerout_x = 0;publicvoid method()Inner1inner1 = new Inner1();publicclass Inner2 /在方法體定義的類publicmethod()out_x= 3;Inner2inner2 = new Inner2();publicclass Inner1 /在方法體外面定義的類在方法體外面定義的類的類型可以是 public,protecte,默認的,private等 4 種類型,這就好像類中定義

58、的成員變量有 4 種類型一樣,它們決定這也可以在外面創(chuàng)建個類的定義對其他類是否可見;對于這種情況,類的實例對象,創(chuàng)建類的實例對象時,一定要先創(chuàng)建外部類的實例對象,然后用這個外部類的實例對象去創(chuàng)建類的實例對象,代碼如下:Outer outer = new Outer();Outer.Inner1 inner1 = outer.newInnner1();在方法定義的類前面不能有類型修飾符,就好像方法中定義的局部變量一樣,但這種類的前面可以使用 final 或 abstract 修飾符。這種類對其他類是不可見的其他類無法這種類,但是這種類創(chuàng)建的實例對象可以傳遞給其他類。這種類必須是先定義,后使用,即

59、類的定義代碼必須出現(xiàn)在使用該類之前,這與方法中的局部變量必須先定義后使用的道理也是一樣的。這種須加 final 修飾符。類可以方法體中的局部變量,但是,該局部變量前必對于這些細節(jié),只要在 eclipse 寫代碼試試,根據(jù)開發(fā)工具提示的各類錯誤信息就可以馬上了解到。在方法體還可以采用如下語法來創(chuàng)建一種類,即定義某一接口或類的子類的同時,還創(chuàng)建了該子類的實例對象,無需為該子類定義名稱:public class Outerpublicvoid start()newThread(new Runable()publicvoid run();).start();最后,在方法外部定義的Nested Clas

60、s,它不再具有類前面可以加上 sic 關(guān)鍵字,從而成為 Sic類的特性,所有,從狹義上講,它不是類。Sic Nested Class 與普通類在運行時的行為和功能上沒區(qū)別,只是在編程時的語法上有一些差別,它可以定義成 public、protected、默認的、private等多種類型,而普通類只能定義成public 和默認的這兩種類型。在外面SicNested Class 類的名稱為“外部類名.類名”。在外面不需要創(chuàng)建外部類的實例對象,就可以直接創(chuàng)建 Sic Nested Class,例如,假設(shè) Inner 是定義在 Outer類中的 Sic Nested Class,那么可以使用如下語句創(chuàng)建

溫馨提示

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

評論

0/150

提交評論