前面部分是問題,后面部分是一些網友給的答案,大家參考吧: ****************************原題部分************************************** 第一,談談final, finally, finalize的區別。 第二,Anonymous Inner Class (匿名內部類) 是否可以extends(繼承)其它類,是否可以implements(實現)interface(接口)? 第三,Static Nested Class 和 Inner Class的不同,說得越多越好(面試題有的很籠統)。 第四,&和&&的區別。 第五,HashMap和Hashtable的區別。 第六,Collection 和 Collections的區別。 第七,什么時候用assert。 第八,GC是什么? 為什么要有GC? 第九,String s = new String("xyz");創建了幾個String Object? 第十,Math.round(11.5)等於多少? Math.round(-11.5)等於多少? 第十一,short s1 = 1; s1 = s1 + 1;有什么錯? short s1 = 1; s1 += 1;有什么錯? 第十二,sleep() 和 wait() 有什么區別? 第十三,Java有沒有goto? 第十四,數組有沒有length()這個方法? String有沒有length()這個方法? 第十五,Overload和Override的區別。Overloaded的方法是否可以改變返回值的類型? 第十六,Set里的元素是不能重復的,那么用什么方法來區分重復與否呢? 是用==還是equals()? 它們有何區別? 第十七,給我一個你最常見到的runtime exception。 第十八,error和exception有什么區別? 第十九,List, Set, Map是否繼承自Collection接口? 第二十,abstract class和interface有什么區別? 第二十一,abstract的method是否可同時是static,是否可同時是native,是否可同時是synchronized? 第二十二,接口是否可繼承接口? 抽象類是否可實現(implements)接口? 抽象類是否可繼承實體類(concrete class)? 第二十三,啟動一個線程是用run()還是start()? 第二十四,構造器Constructor是否可被override? 第二十五,是否可以繼承String類? 第二十六,當一個線程進入一個對象的一個synchronized方法后,其它線程是否可進入此對象的其它方法? 第二十七,try {}里有一個return語句,那么緊跟在這個try后的finally {}里的code會不會被執行,什么時候被執行,在return前還是后? 第二十八,編程題: 用最有效率的方法算出2乘以8等於幾? 第二十九,兩個對象值相同(x.equals(y) == true),但卻可有不同的hash code,這句話對不對? 第三十,當一個對象被當作參數傳遞到一個方法后,此方法可改變這個對象的屬性,并可返回變化后的結果,那么這里到底是值傳遞還是引用傳遞? 第三十一,swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上? 第三十二,編程題: 寫一個Singleton出來。 ***********************第一個人的回答 abcdhy(程旭) ********************************** 比較簡單,不是太難吧. 第一,談談final, finally, finalize的區別。 第二,Anonymous Inner Class (匿名內部類) 是否可以extends(繼承)其它類,是否可以implements(實現)interface(接口)? 第三,Static Nested Class 和 Inner Class的不同,說得越多越好(面試題有的很籠統)。 第四,&和&&的區別。 第五,HashMap和Hashtable的區別。 第六,Collection 和 Collections的區別。 第七,什么時候用assert。 第八,GC是什么? 為什么要有GC? 第九,String s = new String("xyz");創建了幾個String Object? 第十,Math.round(11.5)等於多少? Math.round(-11.5)等於多少? 第十一,short s1 = 1; s1 = s1 + 1;有什么錯? short s1 = 1; s1 += 1;有什么錯? 第十二,sleep() 和 wait() 有什么區別? 第十三,Java有沒有goto? 第十四,數組有沒有length()這個方法? String有沒有length()這個方法? 第十五,Overload和Override的區別。Overloaded的方法是否可以改變返回值的類型? 第十六,Set里的元素是不能重復的,那么用什么方法來區分重復與否呢? 是用==還是equals()? 它們有何區別? 第十七,給我一個你最常見到的runtime exception。 第十八,error和exception有什么區別? 第十九,List, Set, Map是否繼承自Collection接口? 第二十,abstract class和interface有什么區別? 第二十一,abstract的method是否可同時是static,是否可同時是native,是否可同時是synchronized? 第二十二,接口是否可繼承接口? 抽象類是否可實現(implements)接口? 抽象類是否可繼承實體類(concrete class)? 第二十三,啟動一個線程是用run()還是start()? 第二十四,構造器Constructor是否可被override? 第二十五,是否可以繼承String類? 第二十六,當一個線程進入一個對象的一個synchronized方法后,其它線程是否可進入此對象的其它方法? 第二十七,try {}里有一個return語句,那么緊跟在這個try后的finally {}里的code會不會被執行,什么時候被執行,在return前還是后? 第二十八,編程題: 用最有效率的方法算出2乘以8等於幾? 第二十九,兩個對象值相同(x.equals(y) == true),但卻可有不同的hash code,這句話對不對? 第三十,當一個對象被當作參數傳遞到一個方法后,此方法可改變這個對象的屬性,并可返回變化后的結果,那么這里到底是值傳遞還是引用傳遞? 第三十一,swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上? 第三十二,編程題: 寫一個Singleton出來。 花了幾分中,簡單的回答了一下,學得不夠深入,請高手們指點. *************************第二個人的回答 dengyin2000************************************** 第一,談談final, finally, finalize的區別。 第二,Anonymous Inner Class (匿名內部類) 是否可以extends(繼承)其它類,是否可以implements(實現)interface(接口)? 第三,Static Nested Class 和 Inner Class的不同,說得越多越好(面試題有的很籠統)。 第四,&和&&的區別。 第五,HashMap和Hashtable的區別。 第六,Collection 和 Collections的區別。 第九,String s = new String("xyz");創建了幾個String Object? 第十,Math.round(11.5)等於多少? Math.round(-11.5)等於多少? 第十一,short s1 = 1; s1 = s1 + 1;有什么錯? short s1 = 1; s1 += 1;有什么錯? 第十二,sleep() 和 wait() 有什么區別? 搞線程的最愛 第十三,Java有沒有goto? 第十四,數組有沒有length()這個方法? String有沒有length()這個方法? 第十五,Overload和Override的區別。Overloaded的方法是否可以改變返回值的類型? 第十六,Set里的元素是不能重復的,那么用什么方法來區分重復與否呢? 是用==還是equals()? 它們有何區別? 第十七,給我一個你最常見到的runtime exception。 第十八,error和exception有什么區別? Map不是 第二十,abstract class和interface有什么區別? 第二十一,abstract的method是否可同時是static,是否可同時是native,是否可同時是synchronized? 第二十二,接口是否可繼承接口? 抽象類是否可實現(implements)接口? 抽象類是否可繼承實體類(concrete class)? 第二十三,啟動一個線程是用run()還是start()? 第二十四,構造器Constructor是否可被override? 第二十五,是否可以繼承String類? 第二十六,當一個線程進入一個對象的一個synchronized方法后,其它線程是否可進入此對象的其它方法? 第二十七,try {}里有一個return語句,那么緊跟在這個try后的finally {}里的code會不會被執行,什么時候被執行,在return前還是后? 2 << 3 第二十九,兩個對象值相同(x.equals(y) == true),但卻可有不同的hash code,這句話對不對? 第三十,當一個對象被當作參數傳遞到一個方法后,此方法可改變這個對象的屬性,并可返回變化后的結果,那么這里到底是值傳遞還是引用傳遞? 第三十二,編程題: 寫一個Singleton出來。 HashMap允許將null作為一個entry的key或者value,而Hashtable不允許 還有就是,HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey。因為contains方法容易讓人引起誤解。 最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在 Hashtable和HashMap采用的hash/rehash算法都大概一樣,所以性能不會有很大的差異。 ***********************第一個人的補充 abcdhy(程旭) ********************************** 上面的答案有問題:!!!我把有爭議的幾個列出來: 第二,Anonymous Inner Class (匿名內部類) 是否可以extends(繼承)其它類,是否可以implements(實現)interface(接口)? 匿名的內部類是可以 extends(繼承) 其它類的, 這個我做過測試. 第十一,short s1 = 1; s1 = s1 + 1;有什么錯? short s1 = 1; s1 += 1;有什么錯? 第十六,Set里的元素是不能重復的,那么用什么方法來區分重復與否呢? 是用==還是equals()? 它們有何區別? 第二十六,當一個線程進入一個對象的一個synchronized方法后,其它線程是否可進入此對象的其它方法? 第二十九,兩個對象值相同(x.equals(y) == true),但卻可有不同的hash code,這句話對不對? 第三十,當一個對象被當作參數傳遞到一個方法后,此方法可改變這個對象的屬性,并可返回變化后的結果,那么這里到底是值傳遞還是引用傳遞? 我簡單看了一下,大家有什么意見可以一起討論!! ***********************第三個人的回答 abcdhy(程旭) ********************************** 第一,談談final, finally, finalize的區別。 ***********************其它人的補充 abcdhy(程旭) ********************************** 我認為finally應該在return之前運行 這樣寫的目的就是不管出現什么樣的情況,數據庫的連接都應該關閉。 二十七這個很麻煩: public static int test() { 看看結果? 你怎么能這么測呢?這樣你只能證明 System.out.println (test());這條語句是在System.out.println("into finally");這條語句后執行的,而System.out.println (test())這一句中包含了兩步,第一步test()可以理解為return,第二步打印,事實上finally就是在這兩步當中執行的,為什么不拿我的例子來試試呢? public static int test() { zstzah(加亮) 說得對, finally是無論如何都要執行的!! 但我測試了一下 , finally 在 return 之前執行的. public class a {
太長....不寫出來了.
可以
知道80%吧,說不全, 理解起來太難
按位 和 邏輯 與
不同步 同步
接口 實用類
自動內存回收,減少內存泄漏,提高系統穩定性
2個 s 和 "xyz"
不知道.隨機的
需要一個 short ,卻找到一個 int
sleep() 休眠指定時間 wait() 休眠,需要其他線程喚醒
沒有,但 break 可以是實現部分 goto 的功能
沒有 ,有
不可以,Overloaded 必須更改參數
視具體子類而定, 比如 HashSet ,就以 hashCode 來比較.
== 是比較實例的內存地址是不是一樣, 而equals()一般是比較實例的具體內容
NullPointerException ,IOException
error 是不可恢復的,必須停止運行. 而 exception 是可預期,可恢復的.
Map 不是
就是 class 和 interface 的區別,具體的可以隨便說
都不可以
都可以
start();
不可以
不可以
可以,但不能進代對象的 synchronized 方法.
會,出現異常時. 在 return 前
2<<3
可以這樣做,但不符合Java的規范
引用傳遞
long 和 String 不可以. byte 可以
public class aaa {
private aaa ii = new aaa();
private aaa(){};
public aaa get() {
return ii;
}
}
final—修飾符(關鍵字)如果一個類被聲明為final,意味著它不能再派生出新的子類,不能作為父類被繼承。因此一個類不能既被聲明為 abstract的,又被聲明為final的。將變量或方法聲明為final,可以保證它們在使用中不被改變。被聲明為final的變量必須在聲明時給定初值,而在以后的引用中只能讀取,不可修改。被聲明為final的方法也同樣只能使用,不能重載
finally—再異常處理時提供 finally 塊來執行任何清除操作。如果拋出一個異常,那么相匹配的 catch 子句就會執行,然后控制就會進入 finally 塊(如果有的話)。
finalize—方法名。Java 技術允許使用 finalize() 方法在垃圾收集器將對象從內存中清除出去之前做必要的清理工作。這個方法是由垃圾收集器在確定這個對象沒有被引用時對這個對象調用的。它是在 Object 類中定義的,因此所有的類都繼承了它。子類覆蓋 finalize() 方法以整理系統資源或者執行其他清理工作。finalize() 方法是在垃圾收集器刪除對象之前對這個對象調用的。
匿名的內部類是沒有名字的內部類。不能extends(繼承) 其它類,但一個內部類可以作為一個接口,由另一個內部類實現。
Nested Class (一般是C++的說法),Inner Class (一般是JAVA的說法)。Java內部類與C++嵌套類最大的不同就在于是否有指向外部的引用上。具體可見http: //www.frontfree.net/articles/services/view.asp?id=704&page=1
注: 靜態內部類(Inner Class)意味著1創建一個static內部類的對象,不需要一個外部類對象,2不能從一個static內部類的一個對象訪問一個外部類對象
&是位運算符。&&是布爾邏輯運算符。
都屬于Map接口的類,實現了將惟一鍵映射到特定的值上。
HashMap 類沒有分類或者排序。它允許一個 null 鍵和多個 null 值。
Hashtable 類似于 HashMap,但是不允許 null 鍵和 null 值。它也比 HashMap 慢,因為它是同步的。
Collections是個java.util下的類,它包含有各種有關集合操作的靜態方法。
Collection是個java.util下的接口,它是各種集合結構的父接口。
第七,什么時候用assert。
斷言是一個包含布爾表達式的語句,在執行這個語句時假定該表達式為 true。如果表達式計算為 false,那么系統會報告一個 AssertionError。它用于調試目的:
assert(a > 0); // throws an AssertionError if a <= 0
斷言可以有兩種形式:
assert Expression1 ;
assert Expression1 : Expression2 ;
Expression1 應該總是產生一個布爾值。
Expression2 可以是得出一個值的任意表達式。這個值用于生成顯示更多調試信息的 String 消息。
斷言在默認情況下是禁用的。要在編譯時啟用斷言,需要使用 source 1.4 標記:
javac -source 1.4 Test.java
要在運行時啟用斷言,可使用 -enableassertions 或者 -ea 標記。
要在運行時選擇禁用斷言,可使用 -da 或者 -disableassertions 標記。
要系統類中啟用斷言,可使用 -esa 或者 -dsa 標記。還可以在包的基礎上啟用或者禁用斷言。
可以在預計正常情況下不會到達的任何位置上放置斷言。斷言可以用于驗證傳遞給私有方法的參數。不過,斷言不應該用于驗證傳遞給公有方法的參數,因為不管是否啟用了斷言,公有方法都必須檢查其參數。不過,既可以在公有方法中,也可以在非公有方法中利用斷言測試后置條件。另外,斷言不應該以任何方式改變程序的狀態。
第八,GC是什么? 為什么要有GC? (基礎)。
GC是垃圾收集器。Java 程序員不用擔心內存管理,因為垃圾收集器會自動進行管理。要請求垃圾收集,可以調用下面的方法之一:
System.gc()
Runtime.getRuntime().gc()
兩個對象,一個是“xyx”,一個是指向“xyx”的引用對象s。
Math.round(11.5)返回(long)12,Math.round(-11.5)返回(long)-11;
short s1 = 1; s1 = s1 + 1;有錯,s1是short型,s1+1是int型,不能顯式轉化為short型?尚薷臑閟1 =(short)(s1 + 1) 。short s1 = 1; s1 += 1正確。
sleep()方法是使線程停止一段時間的方法。在sleep 時間間隔期滿后,線程不一定立即恢復執行。這是因為在那個時刻,其它線程可能正在運行而且沒有被調度為放棄執行,除非(a)“醒來”的線程具有更高的優先級
(b)正在運行的線程因為其它原因而阻塞。
wait()是線程交互時,如果線程對一個同步對象x 發出一個wait()調用,該線程會暫停執行,被調對象進入等待狀態,直到被喚醒或等待時間到。
Goto—java中的保留字,現在沒有在java中使用。
數組沒有length()這個方法,有length的屬性。
String有有length()這個方法。
方法的重寫Overriding和重載Overloading是Java多態性的不同表現。重寫Overriding是父類與子類之間多態性的一種表現,重載Overloading是一個類中多態性的一種表現。如果在子類中定義某方法與其父類有相同的名稱和參數,我們說該方法被重寫 (Overriding)。子類的對象使用這個方法時,將調用子類中的定義,對它而言,父類中的定義如同被“屏蔽”了。如果在一個類中定義了多個同名的方法,它們或有不同的參數個數或有不同的參數類型,則稱為方法的重載(Overloading)。Overloaded的方法是可以改變返回值的類型。
Set里的元素是不能重復的,那么用iterator()方法來區分重復與否。equals()是判讀兩個Set是否相等。
equals()和==方法決定引用值是否指向同一對象equals()在類中被覆蓋,為的是當兩個分離的對象的內容和類型相配的話,返回真值。
ArithmeticException, ArrayStoreException, BufferOverflowException, BufferUnderflowException, CannotRedoException, CannotUndoException, ClassCastException, CMMException, ConcurrentModificationException, DOMException, EmptyStackException, IllegalArgumentException, IllegalMonitorStateException, IllegalPathStateException, IllegalStateException,
ImagingOpException, IndexOutOfBoundsException, MissingResourceException, NegativeArraySizeException, NoSuchElementException, NullPointerException, ProfileDataException, ProviderException, RasterFormatException, SecurityException, SystemException, UndeclaredThrowableException, UnmodifiableSetException, UnsupportedOperationException
error 表示恢復不是不可能但很困難的情況下的一種嚴重問題。比如說內存溢出。不可能指望程序能處理這樣的情況。
exception 表示一種設計或實現問題。也就是說,它表示如果程序運行正常,從不會發生的情況。
第十九,List, Set, Map是否繼承自Collection接口?
List,Set是
聲明方法的存在而不去實現它的類被叫做抽象類(abstract class),它用于要創建一個體現某些基本行為的類,并為該類聲明方法,但不能在該類中實現該類的情況。不能創建abstract 類的實例。然而可以創建一個變量,其類型是一個抽象類,并讓它指向具體子類的一個實例。不能有抽象構造函數或抽象靜態方法。Abstract 類的子類為它們父類中的所有抽象方法提供實現,否則它們也是抽象類為。取而代之,在子類中實現該方法。知道其行為的其它類可以在類中實現這些方法。
接口(interface)是抽象類的變體。在接口中,所有方法都是抽象的。多繼承性可通過實現這樣的接口而獲得。接口中的所有方法都是抽象的,沒有一個有程序體。接口只可以定義static final成員變量。接口的實現與子類相似,除了該實現類不能從接口定義中繼承行為。當類實現特殊接口時,它定義(即將程序體給予)所有這種接口的方法。然后,它可以在實現了該接口的類的任何對象上調用接口的方法。由于有抽象類,它允許使用接口名作為引用變量的類型。通常的動態聯編將生效。引用可以轉換到接口類型或從接口類型轉換,instanceof 運算符可以用來決定某對象的類是否實現了接口。
都不能
接口可以繼承接口。抽象類可以實現(implements)接口,抽象類是否可繼承實體類,但前提是實體類必須有明確的構造函數。
啟動一個線程是調用start()方法,使線程所代表的虛擬處理機處于可運行狀態,這意味著它可以由JVM調度并執行。這并不意味著線程就會立即運行。run()方法可以產生必須退出的標志來停止一個線程。
構造器Constructor不能被繼承,因此不能重寫Overriding,但可以被重載Overloading。
String類是final類故不可以繼承。
不能,一個對象的一個synchronized方法只能由一個線程訪問。
會執行,在return前執行。
第二十八,編程題: 用最有效率的方法算出2乘以8等於幾?
有C背景的程序員特別喜歡問這種問題。
不對,有相同的hash code。
是值傳遞。Java 編程語言只由值傳遞參數。當一個對象實例作為一個參數被傳遞到方法中時,參數的值就是對該對象的引用。對象的內容可以在被調用的方法中改變,但對象的引用是永遠不會改變的。
第三十一,swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?
switch(expr1)中,expr1是一個整數表達式。因此傳遞給 switch 和 case 語句的參數應該是 int、 short、 char 或者 byte。long,string 都不能作用于swtich。
Singleton模式主要作用是保證在Java應用程序中,一個類Class只有一個實例存在。
一般Singleton模式通常有幾種種形式:
第一種形式: 定義一個類,它的構造函數為private的,它有一個static的private的該類變量,在類初始化時實例話,通過一個public的getInstance方法獲取對它的引用,繼而調用其中的方法。
public class Singleton {
private Singleton(){}
//在自己內部定義自己一個實例,是不是很奇怪?
//注意這是private 只供內部調用
private static Singleton instance = new Singleton();
//這里提供了一個供外部訪問本class的靜態方法,可以直接訪問
public static Singleton getInstance() {
return instance;
}
}
第二種形式:
public class Singleton {
private static Singleton instance = null;
public static synchronized Singleton getInstance() {
//這個方法比上面有所改進,不用每次都進行生成對象,只是第一次
//使用時生成實例,提高了效率!
if (instance==null)
instance=new Singleton();
return instance; }
}
其他形式:
定義一個類,它的構造函數為private的,所有方法為static的。
一般認為第一種形式要更加安全些
第三十三 Hashtable和HashMap
Hashtable繼承自Dictionary類,而HashMap是Java1.2引進的Map interface的一個實現
多個線程訪問Hashtable時,不需要自己為它的方法實現同步,而HashMap
就必須為之提供外同步。
short s1 = 1; s1 += 1 也不是正確。 其中 short s1 = 1 這句會出錯的,因為 1 是 int 的
Set里的元素是不能重復的,那么用iterator()方法來區分重復與否。equals()是判讀兩個Set是否相等。 這個答案也不正確, Set 區分重復元素是有具體子類來實現的.
不能,一個對象的一個synchronized方法只能由一個線程訪問。
這個也有問題, 一個線程進入一個對象的一個synchronized方法后,這個線程占有了該對象的同步鎖. 其他線程是不能進入此對象的其它同步方法的,因為其他線程得不到該對象的同步鎖. 但其他線程可以入此對象的其它非同步方法,因為進入非同步方法,不需要同步鎖.
不對,有相同的hash code。 按照 Java 的編碼規范, x.equals(y) == true 的,hash code一定一樣,但這只是編碼規范,自己編程的時候可以不這么做,一樣可以正常運行.
是值傳遞。Java 編程語言只由值傳遞參數。當一個對象實例作為一個參數被傳遞到方法中時,參數的值就是對該對象的引用。對象的內容可以在被調用的方法中改變,但對象的引用是永遠不會改變的。
暈, 居然說:對象的引用是永遠不會改變 ,對象的引用是什么,是內存地址(uint),怎么變啊. 傳值還是傳引用,是針對"對象"來說的. 對一個"對象的引用" 來說是:傳值還是傳引用 , 有意義嗎??暈
太簡單
第二,Anonymous Inner Class (匿名內部類) 是否可以extends(繼承)其它類,是否可以implements(實現)interface(接口)?
都可以
第三,Static Nested Class 和 Inner Class的不同,說得越多越好。
static 類不存在和外圍類的關聯
第四,&和&&的區別。
太簡單
第五,HashMap和Hashtable的區別。
太簡單
第六,Collection 和 Collections的區別。
太簡單:前者是接口,或者是一個應用類
第七,什么時候用assert。
調試吧
第八,GC是什么? 為什么要有GC?
不用說
第九,String s = new String("xyz");創建了幾個String Object?
廢話,當然是一個,別說引用是對象
第十,Math.round(11.5)等於多少? Math.round(-11.5)等於多少?
我暈
第十一,short s1 = 1; s1 = s1 + 1;有什么錯? short s1 = 1; s1 += 1;有什么錯?
前者編譯不了
第十二,sleep() 和 wait() 有什么區別?
前者自己睡,后者等別人
第十三,Java有沒有goto?
關鍵字,沒有用
第十四,數組有沒有length()這個方法? String有沒有length()這個方法?
數組是屬性,String是方法
第十五,Overload和Override的區別。Overloaded的方法是否可以改變返回值的類型?
重載和覆蓋
第十六,Set里的元素是不能重復的,那么用什么方法來區分重復與否呢? 是用==還是equals()? 它們有何區別?
廢話!怎么會用==?
第十七,給我一個你最常見到的runtime exception。
NullPointerException
第十八,error和exception有什么區別?
錯誤和異常,嚴重度不一樣
第十九,List, Set, Map是否繼承自Collection接口?
Map不是
第二十,abstract class和interface有什么區別?
這個也問?
第二十一,abstract的method是否可同時是static,是否可同時是native,是否可同時是synchronized?
我猜:不能
第二十二,接口是否可繼承接口? 抽象類是否可實現(implements)接口? 抽象類是否可繼承實體類(concrete class)?
當然可以
第二十三,啟動一個線程是用run()還是start()?
廢話,start
第二十四,構造器Constructor是否可被override?
有點可笑
第二十五,是否可以繼承String類?
noway
第二十六,當一個線程進入一個對象的一個synchronized方法后,其它線程是否可進入此對象的其它方法?
當然可以
第二十七,try {}里有一個return語句,那么緊跟在這個try后的finally {}里的code會不會被執行,什么時候被執行,在return前還是后?
當然是return前
第二十八,編程題: 用最有效率的方法算出2乘以8等於幾?
我考 int sb=2<<3;
第二十九,兩個對象值相同(x.equals(y) == true),但卻可有不同的hash code,這句話對不對?
這個問題是sb問給sb的.
可以有不同的hashCode,但是java不建議這樣
第三十,當一個對象被當作參數傳遞到一個方法后,此方法可改變這個對象的屬性,并可返回變化后的結果,那么這里到底是值傳遞還是引用傳遞?
這個問題又是sb問給sb的
是傳值,但是這個值是一個引用
第三十一,swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?
int
第三十二,編程題: 寫一個Singleton出來
雙重check無效
這樣的語句經常被用在獲取數據庫連接的時候
try{
connection = DBPool.get();
.......
//todo
}
catch(SQlException e)
{
//todo
}
finally
{
try{
if(connection != null)
connection.close();
}
catch(SQLException e)
{
connection = null;
//todo
}
}
class TestFinally
{
public static void main(String[] args)
{
System.out.println(test());
}
int i = 0;
try {
System.out.println("try");
return i;
}
finally {
System.out.println("finally");
i = 1;
return i;
}
}
}
int i = 0;
try {
return i;
}
finally {
i = 1;
System.out.println(i);
}
}
測試代碼:
public static void main(String[] args) {
System.out.println (test());
}
public static int test() {
int i = 0;
try {
return i;
}
finally {
System.out.println("into finally");
}
}
}
文章來源于領測軟件測試網 http://www.anti-gravitydesign.com/
版權所有(C) 2003-2010 TestAge(領測軟件測試網)|領測國際科技(北京)有限公司|軟件測試工程師培訓網 All Rights Reserved
北京市海淀區中關村南大街9號北京理工科技大廈1402室 京ICP備2023014753號-2
技術支持和業務聯系:info@testage.com.cn 電話:010-51297073
国产97人人超碰caoprom_尤物国产在线一区手机播放_精品国产一区二区三_色天使久久综合给合久久97