A. j2ee面試題誰有
JAVA程序員面試32問
第一,談談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出來。
以下是答案
第一,談談final, finally, finalize的區別。
final—修飾符(關鍵字)如果一個類被聲明為final,意味著它不能再派生出新的子類,不能作為父類被繼承。因此一個類不能既被聲明為 abstract的,又被聲明為final的。將變數或方法聲明為final,可以保證它們在使用中不被改變。被聲明為final的變數必須在聲明時給定初值,而在以後的引用中只能讀取,不可修改。被聲明為final的方法也同樣只能使用,不能重載
finally—再異常處理時提供 finally 塊來執行任何清除操作。如果拋出一個異常,那麼相匹配的 catch 子句就會執行,然後控制就會進入 finally 塊(如果有的話)。
finalize—方法名。Java 技術允許使用 finalize() 方法在垃圾收集器將對象從內存中清除出去之前做必要的清理工作。這個方法是由垃圾收集器在確定這個對象沒有被引用時對這個對象調用的。它是在 Object 類中定義的,因此所有的類都繼承了它。子類覆蓋 finalize() 方法以整理系統資源或者執行其他清理工作。finalize() 方法是在垃圾收集器刪除對象之前對這個對象調用的。
第二,Anonymous Inner Class (匿名內部類) 是否可以extends(繼承)其它類,是否可以implements(實現)interface(介面)?
匿名的內部類是沒有名字的內部類。不能extends(繼承) 其它類,但一個內部類可以作為一個介面,由另一個內部類實現。
第三,Static Nested Class 和 Inner Class的不同,說得越多越好(面試題有的很籠統)。
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內部類的一個對象訪問一個外部類對象
第四,&和&&的區別。
&是位運算符。&&是布爾邏輯運算符。
第五,HashMap和Hashtable的區別。
都屬於Map介面的類,實現了將惟一鍵映射到特定的值上。
HashMap 類沒有分類或者排序。它允許一個 null 鍵和多個 null 值。
Hashtable 類似於 HashMap,但是不允許 null 鍵和 null 值。它也比 HashMap 慢,因為它是同步的。
第六,Collection 和 Collections的區別。
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()
第九,String s = new String("xyz");創建了幾個String Object?
兩個對象,一個是「xyx」,一個是指向「xyx」的引用對象s。
第十,Math.round(11.5)等於多少? Math.round(-11.5)等於多少?
Math.round(11.5)返回(long)12,Math.round(-11.5)返回(long)-11;
第十一,short s1 = 1; s1 = s1 + 1;有什麼錯? short s1 = 1; s1 += 1;有什麼錯?
short s1 = 1; s1 = s1 + 1;有錯,s1是short型,s1+1是int型,不能顯式轉化為short型。可修改為s1 =(short)(s1 + 1) 。short s1 = 1; s1 += 1正確。
第十二,sleep() 和 wait() 有什麼區別? 搞線程的最愛
sleep()方法是使線程停止一段時間的方法。在sleep 時間間隔期滿後,線程不一定立即恢復執行。這是因為在那個時刻,其它線程可能正在運行而且沒有被調度為放棄執行,除非(a)「醒來」的線程具有更高的優先順序
(b)正在運行的線程因為其它原因而阻塞。
wait()是線程交互時,如果線程對一個同步對象x 發出一個wait()調用,該線程會暫停執行,被調對象進入等待狀態,直到被喚醒或等待時間到。
第十三,Java有沒有goto?
Goto—java中的保留字,現在沒有在java中使用。
第十四,數組有沒有length()這個方法? String有沒有length()這個方法?
數組沒有length()這個方法,有length的屬性。
String有有length()這個方法。
第十五,Overload和Override的區別。Overloaded的方法是否可以改變返回值的類型?
方法的重寫Overriding和重載Overloading是Java多態性的不同表現。重寫Overriding是父類與子類之間多態性的一種表現,重載Overloading是一個類中多態性的一種表現。如果在子類中定義某方法與其父類有相同的名稱和參數,我們說該方法被重寫 (Overriding)。子類的對象使用這個方法時,將調用子類中的定義,對它而言,父類中的定義如同被「屏蔽」了。如果在一個類中定義了多個同名的方法,它們或有不同的參數個數或有不同的參數類型,則稱為方法的重載(Overloading)。Overloaded的方法是可以改變返回值的類型。
第十六,Set里的元素是不能重復的,那麼用什麼方法來區分重復與否呢? 是用==還是equals()? 它們有何區別?
Set里的元素是不能重復的,那麼用iterator()方法來區分重復與否。equals()是判讀兩個Set是否相等。
equals()和==方法決定引用值是否指向同一對象equals()在類中被覆蓋,為的是當兩個分離的對象的內容和類型相配的話,返回真值。
第十七,給我一個你最常見到的runtime exception。
ArithmeticException, ArrayStoreException, BufferOverflowException, BufferUnderflowException, CannotRedoException, CannotUndoException, ClassCastException, CMMException, , DOMException, EmptyStackException, IllegalArgumentException, IllegalMonitorStateException, IllegalPathStateException, IllegalStateException,
ImagingOpException, IndexOutOfBoundsException, MissingResourceException, NegativeArraySizeException, NoSuchElementException, NullPointerException, ProfileDataException, ProviderException, RasterFormatException, SecurityException, SystemException, UndeclaredThrowableException, UnmodifiableSetException, UnsupportedOperationException
第十八,error和exception有什麼區別?
error 表示恢復不是不可能但很困難的情況下的一種嚴重問題。比如說內存溢出。不可能指望程序能處理這樣的情況。
exception 表示一種設計或實現問題。也就是說,它表示如果程序運行正常,從不會發生的情況。
第十九,List, Set, Map是否繼承自Collection介面?
List,Set是
Map不是
第二十,abstract class和interface有什麼區別?
聲明方法的存在而不去實現它的類被叫做抽象類(abstract class),它用於要創建一個體現某些基本行為的類,並為該類聲明方法,但不能在該類中實現該類的情況。不能創建abstract 類的實例。然而可以創建一個變數,其類型是一個抽象類,並讓它指向具體子類的一個實例。不能有抽象構造函數或抽象靜態方法。Abstract 類的子類為它們父類中的所有抽象方法提供實現,否則它們也是抽象類為。取而代之,在子類中實現該方法。知道其行為的其它類可以在類中實現這些方法。
介面(interface)是抽象類的變體。在介面中,所有方法都是抽象的。多繼承性可通過實現這樣的介面而獲得。介面中的所有方法都是抽象的,沒有一個有程序體。介面只可以定義static final成員變數。介面的實現與子類相似,除了該實現類不能從介面定義中繼承行為。當類實現特殊介面時,它定義(即將程序體給予)所有這種介面的方法。然後,它可以在實現了該介面的類的任何對象上調用介面的方法。由於有抽象類,它允許使用介面名作為引用變數的類型。通常的動態聯編將生效。引用可以轉換到介面類型或從介面類型轉換,instanceof 運算符可以用來決定某對象的類是否實現了介面。
第二十一,abstract的method是否可同時是static,是否可同時是native,是否可同時是synchronized?
都不能
第二十二,介面是否可繼承介面? 抽象類是否可實現(implements)介面? 抽象類是否可繼承實體類(concrete class)?
介面可以繼承介面。抽象類可以實現(implements)介面,抽象類是否可繼承實體類,但前提是實體類必須有明確的構造函數。
第二十三,啟動一個線程是用run()還是start()?
啟動一個線程是調用start()方法,使線程所代表的虛擬處理機處於可運行狀態,這意味著它可以由JVM調度並執行。這並不意味著線程就會立即運行。run()方法可以產生必須退出的標志來停止一個線程。
第二十四,構造器Constructor是否可被override?
構造器Constructor不能被繼承,因此不能重寫Overriding,但可以被重載Overloading。
第二十五,是否可以繼承String類?
String類是final類故不可以繼承。
第二十六,當一個線程進入一個對象的一個synchronized方法後,其它線程是否可進入此對象的其它方法?
不能,一個對象的一個synchronized方法只能由一個線程訪問。
第二十七,try {}里有一個return語句,那麼緊跟在這個try後的finally {}里的code會不會被執行,什麼時候被執行,在return前還是後?
會執行,在return前執行。
第二十八,編程題: 用最有效率的方法算出2乘以8等於幾?
有C背景的程序員特別喜歡問這種問題。
2 << 3
第二十九,兩個對象值相同(x.equals(y) == true),但卻可有不同的hash code,這句話對不對?
不對,有相同的hash code。
第三十,當一個對象被當作參數傳遞到一個方法後,此方法可改變這個對象的屬性,並可返回變化後的結果,那麼這里到底是值傳遞還是引用傳遞?
是值傳遞。Java 編程語言只由值傳遞參數。當一個對象實例作為一個參數被傳遞到方法中時,參數的值就是對該對象的引用。對象的內容可以在被調用的方法中改變,但對象的引用是永遠不會改變的。
第三十一,swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?
switch(expr1)中,expr1是一個整數表達式。因此傳遞給 switch 和 case 語句的參數應該是 int、 short、 char 或者 byte。long,string 都不能作用於swtich。
第三十二,編程題: 寫一個Singleton出來。
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的一個實現
HashMap允許將null作為一個entry的key或者value,而Hashtable不允許
還有就是,HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey。因為contains方法容易讓人引起誤解。
最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在
多個線程訪問Hashtable時,不需要自己為它的方法實現同步,而HashMap
就必須為之提供外同步。
Hashtable和HashMap採用的hash/rehash演算法都大概一樣,所以性能不會有很大的差異。
B. 誰有比較全面的的Java面試題
JAVA 面試題匯總
一、 JAVA 基礎知識
1、面向對象的特徵有哪些方面
1.抽象:
抽象就是忽略一個主題中與當前目標無關的那些方面,以便更充分地注意與當前目標有關的方面。抽象並不打算了解全部問題,而只是選擇其中的一部分,暫時不用部分細節。抽象包括兩個方面,一是過程抽象,二是數據抽象。
2.繼承:
繼承是一種聯結類的層次模型,並且允許和鼓勵類的重用,它提供了一種明確表述共性的方法。對象的一個新類可以從現有的類中派生,這個過程稱為類繼承。新類繼承了原始類的特性,新類稱為原始類的派生類(子類),而原始類稱為新類的基類(父類)。派生類可以從它的基類那裡繼承方法和實例變數,並且類可以修改或增加新的方法使之更適合特殊的需要。
3.封裝:
封裝是把過程和數據包圍起來,對數據的訪問只能通過已定義的界面。面向對象計算始於這個基本概念,即現實世界可以被描繪成一系列完全自治、封裝的對象,這些對象通過一個受保護的介面訪問其他對象。
4. 多態性:
多態性是指允許不同類的對象對同一消息作出響應。多態性包括參數化多態性和包含多態性。多態性語言具有靈活、抽象、行為共享、代碼共享的優勢,很好的解決了應用程序函數同名問題。
2、String 是最基本的數據類型嗎?
基本數據類型包括byte、int、char、long、float、double、boolean 和short。
java.lang.String 類是final 類型的,因此不可以繼承這個類、不能修改這個類。為了提高效率節省空間,我們應該用StringBuffer 類
3、int 和 Integer 有什麼區別
Java 提供兩種不同的類型:引用類型和原始類型(或內置類型)。Int 是java 的原始數據類型,Integer是java 為int 提供的封裝類。Java 為每個原始類型提供了封裝類。
原始類型封裝類
booleanBoolean
charCharacter
byteByte
shortShort
intInteger
longLong
floatFloat
doubleDouble
引用類型和原始類型的行為完全不同,並且它們具有不同的語義。引用類型和原始類型具有不同的特徵和用法,它們包括:大小和速度問題,這種類型以哪種類型的數據結構存儲,當引用類型和原始類型用作某個類的實例數據時所指定的預設值。對象引用實例變數的預設值為 null,而原始類型實例變數的預設值與它們的類型有關。
4、String 和StringBuffer 的區別
JAVA 平台提供了兩個類:String 和StringBuffer,它們可以儲存和操作字元串,即包含多個字元的字元數據。這個String 類提供了數值不可改變的字元串。而這個StringBuffer 類提供的字元串進行修改。當你知道字元數據要改變的時候你就可以使用StringBuffer 。典型地,你可以使用
StringBuffers 來動態構造字元數據。
5、運行時異常與一般異常有何異同?
異常表示程序運行過程中可能出現的非正常狀態,運行時異常表示虛擬機的通常操作中可能遇到的異常,是一種常見運行錯誤。java 編譯器要求方法必須聲明拋出可能發生的非運行時異常,但是並不要求必須聲明拋出未被捕獲的運行時異常。
6、說出Servlet 的生命周期,並說出Servlet 和CGI 的區別。
Servlet 被伺服器實例化後,容器運行其init 方法,請求到達時運行其service 方法,service 方法自動派遣運行與請求對應的doXXX 方法(doGet,doPost)等,當伺服器決定將實例銷毀的時候調用其destroy 方法。
與cgi 的區別在於servlet 處於伺服器進程中,它通過多線程方式運行其service 方法,一個實例可以服務於多個請求,並且其實例一般不會銷毀,而CGI 對每個請求都產生新的進程,服務完成後就銷毀,所以效率上低於servlet。
7、說出ArrayList,Vector, LinkedList 的存儲性能和特性
ArrayList 和Vector 都是使用數組方式存儲數據,此數組元素數大於實際存儲的數據以便增加和插入元素,它們都允許直接按序號索引元素,但是插入元素要涉及數組元素移動等內存操作,所以索引數據快而插入數據慢,Vector 由於使用了synchronized 方法(線程安全),通常性能上較ArrayList差,而LinkedList 使用雙向鏈表實現存儲,按序號索引數據需要進行前向或後向遍歷,但是插入數據時只需要記錄本項的前後項即可,所以插入速度較快。
8、EJB 是基於哪些技術實現的?並說出SessionBean 和EntityBean 的區別,StatefulBean 和StatelessBean 的區別。
EJB 包括Session Bean、Entity Bean、Message Driven Bean,基於JNDI、RMI、JAT 等技術實現。
SessionBean 在J2EE 應用程序中被用來完成一些伺服器端的業務操作,例如訪問資料庫、調用其他EJB 組件。EntityBean 被用來代表應用系統中用到的數據。
對於客戶機,SessionBean 是一種非持久性對象,它實現某些在伺服器上運行的業務邏輯。對於客戶機,EntityBean 是一種持久性對象,它代表一個存儲在持久性存儲器中的實體的對象視圖,或是一個由現有企業應用程序實現的實體。
Session Bean 還可以再細分為 Stateful Session Bean 與 Stateless Session Bean ,這兩種的 Session Bean 都可以將系統邏輯放在 method 之中執行,不同的是 Stateful Session Bean 可以記錄呼叫者的狀態,因此通常來說,一個使用者會有一個相對應的 Stateful Session Bean 的實體。
Stateless Session Bean 雖然也是邏輯組件,但是他卻不負責記錄使用者狀態,也就是說當使用者呼叫 Stateless Session Bean 的時候, EJB Container 並不會找尋特定的 Stateless Session Bean 的實體來執行這個 method。換言之,很可能數個使用者在執行某個 Stateless Session Bean 的 methods 時,會是同一個 Bean 的 Instance 在執行。從內存方面來看, Stateful Session Bean 與 Stateless Session Bean 比較, Stateful Session Bean 會消耗 J2EE Server 較多的內存,然而 Stateful Session Bean 的優勢卻在於他可以維持使用者的狀態。
9、Collection 和 Collections 的區別。
Collection 是集合類的上級介面,繼承與他的介面主要有Set 和List.
Collections 是針對集合類的一個幫助類,他提供一系列靜態方法實現對各種集合的搜索、排序、線程安全化等操作。
10、&和&&的區別。
&是位運算符,表示按位與運算,&&是邏輯運算符,表示邏輯與(and)。
11、HashMap 和Hashtable 的區別。
HashMap 是Hashtable 的輕量級實現(非線程安全的實現),他們都完成了Map 介面,主要區別在於HashMap 允許空(null)鍵值(key),由於非線程安全,效率上可能高於Hashtable。
HashMap 允許將null 作為一個entry 的key 或者value,而Hashtable 不允許。
HashMap 把Hashtable 的contains 方法去掉了,改成containsvalue 和containsKey。因為contains方法容易讓人引起誤解。Hashtable 繼承自Dictionary 類,而HashMap 是Java1.2 引進的Map interface 的一個實現。最大的不同是,Hashtable 的方法是Synchronize 的,而HashMap 不是,在多個線程訪問Hashtable,不需要自己為它的方法實現同步,而HashMap 就必須為之提供外同步。Hashtable 和HashMap 採用的hash/rehash 演算法都大概一樣,所以性能不會有很大的差異。
12、final, finally, finalize 的區別。
final 用於聲明屬性,方法和類,分別表示屬性不可變,方法不可覆蓋,類不可繼承。finally 是異常處理語句結構的一部分,表示總是執行。
finalize 是Object 類的一個方法,在垃圾收集器執行的時候會調用被回收對象的此方法,可以覆蓋此方法提供垃圾收集時的其他資源回收,例如關閉文件等。
final—修飾符(關鍵字)如果一個類被聲明為final,意味著它不能再派生出新的子類,不能作為父類被繼承。因此一個類不能既被聲明為 abstract 的,又被聲明為final 的。將變數或方法聲明為final,可以保證它們在使用中不被改變。被聲明為final 的變數必須在聲明時給定初值,而在以後的引用中只能讀取,不可修改。被聲明為final 的方法也同樣只能使用,不能重載。
finally—再異常處理時提供 finally 塊來執行任何清除操作。如果拋出一個異常,那麼相匹配的 catch 子句就會執行,然後控制就會進入 finally 塊(如果有的話)。
finalize—方法名。Java 技術允許使用 finalize() 方法在垃圾收集器將對象從內存中清除出去之前做必要的清理工作。這個方法是由垃圾收集器在確定這個對象沒有被引用時對這個對象調用的。它是在 Object 類中定義的,因此所有的類都繼承了它。子類覆蓋 finalize() 方法以整理系統資源或者執行其他清理工作。finalize() 方法是在垃圾收集器刪除對象之前對這個對象調用的。
13、sleep() 和 wait() 有什麼區別?
sleep 是線程類(Thread)的方法,導致此線程暫停執行指定時間,給執行機會給其他線程,但是監控狀態依然保持,到時後會自動恢復。調用sleep 不會釋放對象鎖。
wait 是Object 類的方法,對此對象調用wait 方法導致本線程放棄對象鎖,進入等待此對象的等待鎖定池,只有針對此對象發出notify 方法(或notifyAll)後本線程才進入對象鎖定池准備獲得對象鎖進入運行狀態。
sleep()方法是使線程停止一段時間的方法。在sleep 時間間隔期滿後,線程不一定立即恢復執行。這是因為在那個時刻,其它線程可能正在運行而且沒有被調度為放棄執行,除非(a)「醒來」的線程具有更高的優先順序 (b)正在運行的線程因為其它原因而阻塞。wait()是線程交互時,如果線程對一個同步對象x 發出一個wait()調用,該線程會暫停執行,被調對象進入等待狀態,直到被喚醒或等待時間到。
14、Overload 和Override 的區別。Overloaded 的方法是否可以改變返回值的類型?
方法的重寫Overriding 和重載Overloading 是Java 多態性的不同表現。重寫Overriding 是父類與子類之間多態性的一種表現,重載Overloading 是一個類中多態性的一種表現。如果在子類中定義某方法與其父類有相同的名稱和參數,我們說該方法被重寫 (Overriding)。子類的對象使用這個方法時,將調用子類中的定義,對它而言,父類中的定義如同被「屏蔽」了。如果在一個類中定義了多個同名的方法,它們或有不同的參數個數或有不同的參數類型,則稱為方法的重載(Overloading)。
Overloaded 的方法是可以改變返回值的類型。
15、error 和exception 有什麼區別?
error 表示恢復不是不可能但很困難的情況下的一種嚴重問題。比如說內存溢出。不可能指望程序能處理這樣的情況。
exception 表示一種設計或實現問題。也就是說,它表示如果程序運行正常,從不會發生的情況。
16、同步和非同步有何異同,在什麼情況下分別使用他們?舉例說明。
如果數據將在線程間共享。例如正在寫的數據以後可能被另一個線程讀到,或者正在讀的數據可能已經被另一個線程寫過了,那麼這些數據就是共享數據,必須進行同步存取。
當應用程序在對象上調用了一個需要花費很長時間來執行的方法,並且不希望讓程序等待方法的返回時,就應該使用非同步編程,在很多情況下採用非同步途徑往往更有效率。
17、abstract class 和interface 有什麼區別?
聲明方法的存在而不去實現它的類被叫做抽象類(abstract class),它用於要創建一個體現某些基本行為的類,並為該類聲明方法,但不能在該類中實現該類的情況。不能創建abstract 類的實例。然而可以創建一個變數,其類型是一個抽象類,並讓它指向具體子類的一個實例。不能有抽象構造函數或抽象靜態方法。Abstract 類的子類為它們父類中的所有抽象方法提供實現,否則它們也是抽象類為。取而代之,在子類中實現該方法。知道其行為的其它類可以在類中實現這些方法。介面(interface)是抽象類的變體。在介面中,所有方法都是抽象的。多繼承性可通過實現這樣的介面而獲得。介面中的所有方法都是抽象的,沒有一個有程序體。介面只可以定義static final 成員變數。介面的實現與子類相似,除了該實現類不能從介面定義中繼承行為。當類實現特殊介面時,它定義(即將程序體給予)所有這種介面的方法。然後,它可以在實現了該介面的類的任何對象上調用介面的方法。由於有抽象類,它允許使用介面名作為引用變數的類型。通常的動態聯編將生效。引用可以轉換到介面類型或從介面類型轉換,instanceof 運算符可以用來決定某對象的類是否實現了介面。
18、heap 和stack 有什麼區別。
棧是一種線形集合,其添加和刪除元素的操作應在同一段完成。棧按照後進先出的方式進行處理。堆是棧的一個組成元素
19、forward 和redirect 的區別
forward 是伺服器請求資源,伺服器直接訪問目標地址的URL,把那個URL 的響應內容讀取過來,然後把這些內容再發給瀏覽器,瀏覽器根本不知道伺服器發送的內容是從哪兒來的,所以它的地址欄中還是原來的地址。
redirect 就是服務端根據邏輯,發送一個狀態碼,告訴瀏覽器重新去請求那個地址,一般來說瀏覽器會用剛才請求的所有參數重新請求,所以session,request 參數都可以獲取。
20、EJB 與JAVA BEAN 的區別?
Java Bean 是可復用的組件,對Java Bean 並沒有嚴格的規范,理論上講,任何一個Java 類都可以是一個Bean。但通常情況下,由於Java Bean 是被容器所創建(如Tomcat)的,所以Java Bean 應具有一個無參的構造器,另外,通常Java Bean 還要實現Serializable 介面用於實現Bean 的持久性。Java Bean 實際上相當於微軟COM 模型中的本地進程內COM 組件,它是不能被跨進程訪問的。Enterprise Java Bean 相當於DCOM,即分布式組件。它是基於Java 的遠程方法調用(RMI)技術的,所以EJB 可以被遠程訪問(跨進程、跨計算機)。但EJB 必須被布署在諸如Webspere、WebLogic 這樣的容器中,EJB 客戶從不直接訪問真正的EJB 組件,而是通過其容器訪問。EJB 容器是EJB 組件的代理,EJB 組件由容器所創建和管理。客戶通過容器來訪問真正的EJB 組件。
21、Static Nested Class 和 Inner Class 的不同。
Static Nested Class 是被聲明為靜態(static)的內部類,它可以不依賴於外部類實例被實例化。而通常的內部類需要在外部類實例化後才能實例化。
22、JSP 中動態INCLUDE 與靜態INCLUDE 的區別?
動態INCLUDE 用jsp:include 動作實現 <jsp:include page="included.jsp" flush="true"/>它總是會檢查所含文件中的變化,適合用於包含動態頁面,並且可以帶參數。
靜態INCLUDE 用include 偽碼實現, 定不會檢查所含文件的變化, 適用於包含靜態頁面
<%@ include file="included.htm" %>
23、什麼時候用assert。
assertion(斷言)在軟體開發中是一種常用的調試方式,很多開發語言中都支持這種機制。在實現中,assertion 就是在程序中的一條語句,它對一個boolean 表達式進行檢查,一個正確程序必須保證這個boolean 表達式的值為true;如果該值為false,說明程序已經處於不正確的狀態下,系統將給出警告或退出。一般來說,assertion 用於保證程序最基本、關鍵的正確性。assertion 檢查通常在開發和測試時開啟。為了提高性能,在軟體發布後,assertion 檢查通常是關閉的。
斷言是一個包含布爾表達式的語句,在執行這個語句時假定該表達式為 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 標記。還可以在包的基礎上啟用或者禁用斷言。
可以在預計正常情況下不會到達的任何位置上放置斷言。斷言可以用於驗證傳遞給私有方法的參數。不過,斷言不應該用於驗證傳遞給公有方法的參數,因為不管 是否啟用了斷言,公有方法都必須檢查其參數。不過,既可以在公有方法中,也可以在非公有方法中利用斷言測試後置條件。另外,斷言不應該以任何方式改變程序 的狀態。
24、GC 是什麼? 為什麼要有GC?
GC 是垃圾收集的意思(Gabage Collection),內存處理是編程人員容易出現問題的地方,忘記或者錯誤的內存回收會導致程序或系統的不穩定甚至崩潰,Java 提供的GC 功能可以自動監測對象是否超過作用域從而達到自動回收內存的目的,Java 語言沒有提供釋放已分配內存的顯示操作方法。
25、short s1 = 1; s1 = s1 + 1;有什麼錯? short s1 = 1; s1 += 1;有什麼錯?
short s1 = 1; s1 = s1 + 1; (s1+1 運算結果是int 型,需要強制轉換類型)
short s1 = 1; s1 += 1;(可以正確編譯)
26、Math.round(11.5)等於多少? Math.round(-11.5)等於多少?
Math.round(11.5)==12
Math.round(-11.5)==-11
round 方法返回與參數最接近的長整數,參數加1/2 後求其floor.
27、String s = new String("xyz" ;創建了幾個String Object?
兩個對象,一個是「xyx」,一個是指向「xyz」的引用對象s。
28、如果系統要使用超大整數(超過long 長度范圍),請你設計一個數據結構來存儲這種超大型數字以及設計一種演算法來實現超大整數加法運算)。
public class BigInt()
{
int[] ArrOne = new ArrOne[1000];
String intString="";
public int[] Arr(String s)
{
intString = s;
for(int i=0;i<ArrOne.leght;i++)
29、Java 有沒有goto?
java 中的保留字,現在沒有在java 中使用。
30、啟動一個線程是用run()還是start()?
啟動一個線程是調用start()方法,使線程所代表的虛擬處理機處於可運行狀態,這意味著它可以由JVM 調度並執行。這並不意味著線程就會立即運行。run()方法可以產生必須退出的標志來停止一個線程。
來個郵箱了,太多了傳不上去。我可以發給你。
C. 游戲公司。。上海EA、上海巨人、北京完美。哪家總體情況好,包括薪資,待遇,加班情況,未來發展等等。
當然是EA了
記得有一次去EA的路上,我一上車發現角落裡只有一個空位了,旁邊坐著一個御姐,嘿嘿,我忙走過去一屁股坐下,那漂亮御姐很熟練的皺皺眉頭,職業性的使勁往旁邊挪。
"到哪?"
"友力國際大廈。"
"哪?" 這個面部肌肉僵硬的售票員一臉不解。
"友力國際大廈,唔",一說完我明白了,忙改口,"長壽路江寧路。"
"友力國際大廈?你是EA的吧!"丫更吃驚了。這么高的分貝使全車的人都回頭。
我前座的一位再老就不能說話的那種老人,悠悠的問:"小夥子,你真是EA的?"
這似乎是所有人所期盼得到答案的問題。大家盯著我看,看得我都臉紅。我更感受到了旁邊MM由於迅速靠近我所不得不散發出來的香水味。
我利索的從錢包里拿出公交卡,一不小心公司門卡掉了出來,於是全車廂傳閱,那位長者鄭重地戴上老花鏡,眯著眼睛吃力地掃描的我的門卡,然後老淚縱橫……
大家相互傳閱的紅火場面令那個長著死魚眼睛的售票員的死魚眼睛濕潤了。
一位年輕人不無揶揄的說,"聽說你們EA一畢業一個月就二十萬啊。"
我笑了笑,社會謠言真多,"沒有沒有?大多數人都是七八萬,哪有上二十萬的。"又是一陣轟動。不知是誰低聲說:"老子一年還沒那麼多呢……"
總算御姐有機會插話了,
"朋友你工作幾年啦?"
"下個月就8年。"我鉚足了力氣掩飾我內心的激動。雖然EA男女比例10:1。
"我也工作8年了啊。我也在長壽路江寧路下,去聽你們總監的課,聽說你們總監在游戲製作方面很有建樹。"
"噢,你想再來我們公司面試?同學,你哪個公司的?"
御姐警覺地望瞭望四周,輕聲地吐出兩個字"暴雪"。
我忙拍馬屁,"不錯了,暴雪嘛!"
御姐一聽更加心酸,"我剛畢業也來EA面試過,可惜上機測試沒過。"
類似的故事我聽了一遍又一遍暴雪員工的EA情結。她把"測試"說得很重,於是車里一陣扼腕嘆息之聲。
長者搖搖頭,"長太息以掩涕兮,哀暴雪員工之多艱!"
但見售票員死灰復燃的臉上簌簌留下的淚水,接著,他痛苦地說起了革命家史,三年前,去EA面試,落榜了,
去培訓班學習,再投簡歷去EA,拒絕,去培訓班學習,再投,再拒絕,於是出來工作了……
我明白了,能進EA的人,幸福是相似的,與EA失之交臂的人,各有各的不幸。
我懷著這樣的心情離開了烈士陵園……
錯了錯了,是我懷著這樣的心情帶領御姐下了車。
背後傳來了幼稚的童聲:"媽媽,我長大也要去EA上班!"
我回過頭,車上那位婦女的表情告訴我,她是世界上最幸福的母親。
D. EA20 面試前要有哪些准備(佚名)面試求職
面試前的准備:
面試前要先預想主考官會問的問題,並准備謹慎而有條理地回答。事先有準備的人,表情和肢體語言比較篤定從容,且具備較好的回應能力。大學畢業生由於缺乏面試經驗,可事先找朋友練習面試技巧。面試時最好提前10分鍾到達地點,先去洗手間放鬆一下,整理一下思路,還可最後檢查一下自己的儀容,整理因擠公車而弄亂的發型,女士還可趁機補補妝。
E. 在哪裡可以找到歷年公務員面試真題呢
您可以到我們的網站查詢真題
F. 重分懸賞JAVA面試問題
JAVA程序員面試32問
第一,談談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出來。
以下是答案
第一,談談final, finally, finalize的區別。
final—修飾符(關鍵字)如果一個類被聲明為final,意味著它不能再派生出新的子類,不能作為父類被繼承。因此一個類不能既被聲明為 abstract的,又被聲明為final的。將變數或方法聲明為final,可以保證它們在使用中不被改變。被聲明為final的變數必須在聲明時給定初值,而在以後的引用中只能讀取,不可修改。被聲明為final的方法也同樣只能使用,不能重載
finally—再異常處理時提供 finally 塊來執行任何清除操作。如果拋出一個異常,那麼相匹配的 catch 子句就會執行,然後控制就會進入 finally 塊(如果有的話)。
finalize—方法名。Java 技術允許使用 finalize() 方法在垃圾收集器將對象從內存中清除出去之前做必要的清理工作。這個方法是由垃圾收集器在確定這個對象沒有被引用時對這個對象調用的。它是在 Object 類中定義的,因此所有的類都繼承了它。子類覆蓋 finalize() 方法以整理系統資源或者執行其他清理工作。finalize() 方法是在垃圾收集器刪除對象之前對這個對象調用的。
第二,Anonymous Inner Class (匿名內部類) 是否可以extends(繼承)其它類,是否可以implements(實現)interface(介面)?
匿名的內部類是沒有名字的內部類。不能extends(繼承) 其它類,但一個內部類可以作為一個介面,由另一個內部類實現。
第三,Static Nested Class 和 Inner Class的不同,說得越多越好(面試題有的很籠統)。
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內部類的一個對象訪問一個外部類對象
第四,&和&&的區別。
&是位運算符。&&是布爾邏輯運算符。
第五,HashMap和Hashtable的區別。
都屬於Map介面的類,實現了將惟一鍵映射到特定的值上。
HashMap 類沒有分類或者排序。它允許一個 null 鍵和多個 null 值。
Hashtable 類似於 HashMap,但是不允許 null 鍵和 null 值。它也比 HashMap 慢,因為它是同步的。
第六,Collection 和 Collections的區別。
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()
第九,String s = new String("xyz");創建了幾個String Object?
兩個對象,一個是「xyx」,一個是指向「xyx」的引用對象s。
第十,Math.round(11.5)等於多少? Math.round(-11.5)等於多少?
Math.round(11.5)返回(long)12,Math.round(-11.5)返回(long)-11;
第十一,short s1 = 1; s1 = s1 + 1;有什麼錯? short s1 = 1; s1 += 1;有什麼錯?
short s1 = 1; s1 = s1 + 1;有錯,s1是short型,s1+1是int型,不能顯式轉化為short型。可修改為s1 =(short)(s1 + 1) 。short s1 = 1; s1 += 1正確。
第十二,sleep() 和 wait() 有什麼區別? 搞線程的最愛
sleep()方法是使線程停止一段時間的方法。在sleep 時間間隔期滿後,線程不一定立即恢復執行。這是因為在那個時刻,其它線程可能正在運行而且沒有被調度為放棄執行,除非(a)「醒來」的線程具有更高的優先順序
(b)正在運行的線程因為其它原因而阻塞。
wait()是線程交互時,如果線程對一個同步對象x 發出一個wait()調用,該線程會暫停執行,被調對象進入等待狀態,直到被喚醒或等待時間到。
第十三,Java有沒有goto?
Goto—java中的保留字,現在沒有在java中使用。
第十四,數組有沒有length()這個方法? String有沒有length()這個方法?
數組沒有length()這個方法,有length的屬性。
String有有length()這個方法。
第十五,Overload和Override的區別。Overloaded的方法是否可以改變返回值的類型?
方法的重寫Overriding和重載Overloading是Java多態性的不同表現。重寫Overriding是父類與子類之間多態性的一種表現,重載Overloading是一個類中多態性的一種表現。如果在子類中定義某方法與其父類有相同的名稱和參數,我們說該方法被重寫 (Overriding)。子類的對象使用這個方法時,將調用子類中的定義,對它而言,父類中的定義如同被「屏蔽」了。如果在一個類中定義了多個同名的方法,它們或有不同的參數個數或有不同的參數類型,則稱為方法的重載(Overloading)。Overloaded的方法是可以改變返回值的類型。
第十六,Set里的元素是不能重復的,那麼用什麼方法來區分重復與否呢? 是用==還是equals()? 它們有何區別?
Set里的元素是不能重復的,那麼用iterator()方法來區分重復與否。equals()是判讀兩個Set是否相等。
equals()和==方法決定引用值是否指向同一對象equals()在類中被覆蓋,為的是當兩個分離的對象的內容和類型相配的話,返回真值。
第十七,給我一個你最常見到的runtime exception。
ArithmeticException, ArrayStoreException, BufferOverflowException, BufferUnderflowException, CannotRedoException, CannotUndoException, ClassCastException, CMMException, , DOMException, EmptyStackException, IllegalArgumentException, IllegalMonitorStateException, IllegalPathStateException, IllegalStateException,
ImagingOpException, IndexOutOfBoundsException, MissingResourceException, NegativeArraySizeException, NoSuchElementException, NullPointerException, ProfileDataException, ProviderException, RasterFormatException, SecurityException, SystemException, UndeclaredThrowableException, UnmodifiableSetException, UnsupportedOperationException
第十八,error和exception有什麼區別?
error 表示恢復不是不可能但很困難的情況下的一種嚴重問題。比如說內存溢出。不可能指望程序能處理這樣的情況。
exception 表示一種設計或實現問題。也就是說,它表示如果程序運行正常,從不會發生的情況。
第十九,List, Set, Map是否繼承自Collection介面?
List,Set是
Map不是
第二十,abstract class和interface有什麼區別?
聲明方法的存在而不去實現它的類被叫做抽象類(abstract class),它用於要創建一個體現某些基本行為的類,並為該類聲明方法,但不能在該類中實現該類的情況。不能創建abstract 類的實例。然而可以創建一個變數,其類型是一個抽象類,並讓它指向具體子類的一個實例。不能有抽象構造函數或抽象靜態方法。Abstract 類的子類為它們父類中的所有抽象方法提供實現,否則它們也是抽象類為。取而代之,在子類中實現該方法。知道其行為的其它類可以在類中實現這些方法。
介面(interface)是抽象類的變體。在介面中,所有方法都是抽象的。多繼承性可通過實現這樣的介面而獲得。介面中的所有方法都是抽象的,沒有一個有程序體。介面只可以定義static final成員變數。介面的實現與子類相似,除了該實現類不能從介面定義中繼承行為。當類實現特殊介面時,它定義(即將程序體給予)所有這種介面的方法。然後,它可以在實現了該介面的類的任何對象上調用介面的方法。由於有抽象類,它允許使用介面名作為引用變數的類型。通常的動態聯編將生效。引用可以轉換到介面類型或從介面類型轉換,instanceof 運算符可以用來決定某對象的類是否實現了介面。
第二十一,abstract的method是否可同時是static,是否可同時是native,是否可同時是synchronized?
都不能
第二十二,介面是否可繼承介面? 抽象類是否可實現(implements)介面? 抽象類是否可繼承實體類(concrete class)?
介面可以繼承介面。抽象類可以實現(implements)介面,抽象類是否可繼承實體類,但前提是實體類必須有明確的構造函數。
第二十三,啟動一個線程是用run()還是start()?
啟動一個線程是調用start()方法,使線程所代表的虛擬處理機處於可運行狀態,這意味著它可以由JVM調度並執行。這並不意味著線程就會立即運行。run()方法可以產生必須退出的標志來停止一個線程。
第二十四,構造器Constructor是否可被override?
構造器Constructor不能被繼承,因此不能重寫Overriding,但可以被重載Overloading。
第二十五,是否可以繼承String類?
String類是final類故不可以繼承。
第二十六,當一個線程進入一個對象的一個synchronized方法後,其它線程是否可進入此對象的其它方法?
不能,一個對象的一個synchronized方法只能由一個線程訪問。
第二十七,try {}里有一個return語句,那麼緊跟在這個try後的finally {}里的code會不會被執行,什麼時候被執行,在return前還是後?
會執行,在return前執行。
第二十八,編程題: 用最有效率的方法算出2乘以8等於幾?
有C背景的程序員特別喜歡問這種問題。
2 << 3
第二十九,兩個對象值相同(x.equals(y) == true),但卻可有不同的hash code,這句話對不對?
不對,有相同的hash code。
第三十,當一個對象被當作參數傳遞到一個方法後,此方法可改變這個對象的屬性,並可返回變化後的結果,那麼這里到底是值傳遞還是引用傳遞?
是值傳遞。Java 編程語言只由值傳遞參數。當一個對象實例作為一個參數被傳遞到方法中時,參數的值就是對該對象的引用。對象的內容可以在被調用的方法中改變,但對象的引用是永遠不會改變的。
第三十一,swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?
switch(expr1)中,expr1是一個整數表達式。因此傳遞給 switch 和 case 語句的參數應該是 int、 short、 char 或者 byte。long,string 都不能作用於swtich。
第三十二,編程題: 寫一個Singleton出來。
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的一個實現
HashMap允許將null作為一個entry的key或者value,而Hashtable不允許
還有就是,HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey。因為contains方法容易讓人引起誤解。
最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在
多個線程訪問Hashtable時,不需要自己為它的方法實現同步,而HashMap
就必須為之提供外同步。
Hashtable和HashMap採用的hash/rehash演算法都大概一樣,所以性能不會有很大的差異。
G. 移動通信專業面試時會被問到的問題及回答技巧
一方面面試時注意1,自我介紹一定要把握好時間,最好在2分鍾。
2,回答問題時要看著HR的眼睛。
3,當HR問到所學專業與應聘職位的關系時,最好保持中立。
4,大談特吹自己的實踐能力與優勢,肯定會有加分。
5,凸現自己的綜合素質及適應力。
6,向HR提問要先出風度,千萬不要問自己都覺得沒意思之類的問題。
7,不要隨便打斷HR的話,盡管她(他)會隨時打斷你的話。
8,如果你被HR問到無話可說,就不停的微笑和點頭。
9,做到以上八條,你會發現自己真的很想走人了,不過,相信很快就可以收到下一輪的面試通知。二方面一般專業知識會問以下這些:(給你套題吧,是移動的筆試題,你好好准備下)1. GSM網中,一個S2/2/2的基站最多可同時容納42個無線用戶的通話。
2. 移動通信系統目前採用_FDMA_、_TDMA_和_CDMA_三種多址方式,GSM採用FDMA/TDMA(或TDMA)多址方式。
3. GSM系統按照功能分為MSS、BSS和 MS等三部分。
4. 無線介面上CCCH包括 PCH 、AGCH 、RACH三類信道。
5. 常見的基站組網方式有 星 形、 鏈 形、 樹 形 和環形靈活組網。
6. 在GSM系統中,移動台(MS)與基站(BTS)間傳輸的數字話音信號速率為 13 Kbit/s, 移動交換局(MSC)與基站間傳輸的數字話音信號速率為 64 Kbit/s,因此在BSS 與MSC之間需增加碼型變換設備。
7. 分集技術是對付快衰落的有效方法,在眾多的分集技術中,我們目前在市區最常用的是
__空間分集__。在郊區最常用的是 極化分集 。
8. 切換一般是指MS在 通話 狀態(空閑、通話)下由於位置改變而要進行的行為。
9. 在GSM網中,一個2M最大能帶 15 個載頻。
10. 數字蜂窩PLMN可提供的業務分為基本業務和補充業務。二、判斷題:
1. 如果手機沒有SIM卡,就不能進行任何呼叫了。 (錯誤)
2. HLR中存儲著移動用戶識別號碼、訪問能力、用戶類別和補充業務等數據。(正確)
3. MSC尋呼被叫用戶時,一定是在整個VLR范圍發送尋呼命令。 (錯誤)
4. 移動用戶發起位置更新時,並非每次都由VLR分配新的TMSI。 (正確)
5. GSM900/GSM1800雙頻系統可以共用交換子系統和基站控制器,還可以共基站。(正確)
6. GSM網個人鑒權密鑰Kc存放在僅存放在HLR/AUC 里。 (錯誤)
7. TCH與SACCH組合時51幀為一復幀,控制信道組合時26幀構成一復幀。 ( 錯誤 )
8. GSM蜂窩小區的覆蓋半徑在設計時,即使把功率輸出調至最大,地形再平坦,其覆蓋范圍也不可能超過35公里。(正確)
9. 在關機注冊中,手機只有受到系統證實消息才能關機 (錯誤)
10. 在空閑狀態時,可能進行軟切換 (正確)
11. 天饋線系統的駐波比要大於1.4. (正確)三、選擇題:
1、下面哪些信道類型屬於控制信道 A、C、D
A、AGCH B、TCH/F C、FCCH D、SACCH
2、一個S2/2/2的基站最多同時可容納多少個無線用戶在通話? B
A、36 B、42 C、 48 D、 64
3、天饋系統駐波比變差的可能原因有:A、B、C、D
A.接頭沒有接好
B 接頭密封不好導致進水
C.天饋避雷器駐波大
D.饋線某處有折損
5、以下哪些措施是GSM系統用來提高頻譜效率的( 1、2、4 )
1)跳頻 2)DTX 3)信道編碼 4)功率控制
6、以下屬於雙向信道的是( 1 )
1)SACCH 2)AGCH 3)BCCH
7、上行鏈路的測量報告是在( 3 )上傳送的:
1)SDCCH 2)RACH 3)SACCH 4)FACCH
8、西門子MSC可以和MOTOROLA的BSC互連的原因是因為存在標準的( 1 )介面:
1)A 2)B 3)C 4)D
9、掉話與切換失敗有那些共同的可能原因: abcd
A 干擾程度較高 B 硬體有故障 C 天饋線聯接方向錯誤D 越區
10、 絕大多數情況下,基於小區擁塞的切換HOTRAFFIC是:b
A 服務小區的中心的手機用戶切換到其他小區上,以緩解擁塞;
B 服務小區的邊沿的手機用戶切換到其他小區上,以緩解擁塞;
C 將服務小區中新的提出信道佔用請求的用戶切換到其他小區上,以緩解擁塞。
11、處理切換失敗的思路: abcd
A 查干擾源 B 排除可能的硬體故障 C 減少小區間的交叉覆蓋區 D 排除設計上的不足(有同頻同BISC/同頻小區間互為鄰小區)
蜂窩的切換失敗的處理: e
A 調整頻率及BSIC設計 B 調整鄰小區的定義 C 查找室內分布系統的問題 D 切換門限的調節 E 以上均可以
11、 MS對目標小區進行重選時,不需要核對的信息是: d
A cro B Cell bar C Location Area D Time advance
12、 加快切換速度可以: bcd
A 切換成功率就會下降,
B 適當減少掉話,
C 切換量會增加,
D BSC負荷會增加
13、 掉話的原因: abc
A 干擾程度較高 B 硬體有故障 C 天饋線聯接方向錯誤
14、 處理掉話的思路: abcd
A 查干擾源 B 排除可能的硬體故障 C 減少或增加小區間的交叉覆蓋區 D 查天線的連接
15、 LAC區設置不當而導致的位置更新過多,手機可能會有什麼現象:d
A 手機有信號,被叫錄音提示不在服務區
B 手機有信號,無法作被叫
C 手機信號不穩
D 以上全是
16、 小區的信號很強但用戶不能起呼(可以切換進入)的原因:d
A 有強外部干擾 B 小區未在交換中定義 C 手機制式與GSM協議不匹配(如未升級的某些手機在開通DCS1800的區域)
D 小區未定義SDCCH信道。
20、位置更新中利用的邏輯信道是哪個:b
A,TCH B,SDCCH C,SACCH D,FACCH
21、解決位置更新過多的方法有:abd
A,重新規劃位置區
B,位置區邊界盡量避開小區重選頻繁的地段
C,給邊界處的小區多配置信令信道
D,修改CellReselectHysteresis參數
22、GSM網路採用900/1800MHz頻段,其中移動台發、基站收為:B
A 908-914MHz B 909-915MHz C 910-916MHz
25、當移動用戶使用分組數據業務的時候,需要給用戶分配IP地址。與核心網分組部分有關的設備也應當分配IP地址,例如:A C
A BSC 、PCF B PDSN、RADIUS伺服器和HLR C DNS伺服器、防火牆和各種應用伺服器
27、GSM/CDMA網內主叫號碼傳遞原則規定中,正確的是:A C
A網內話路接續過程中,原則上不對主叫號碼做變換 B GSM/CDMA用戶做主叫時,在網內主叫號碼格式採用國際有效號碼 C國內其他網的主叫號碼在接入聯通網的GMSC時變為標准格式,並在網內進行傳送
28、下面那些論述是錯誤的:ABC
A,鑒權過程在每次通話前或位置更新前均必定會發生。
B,Ciphering過程在每次通話前或位置更新前均必定會發生。
C,TMSI再分配過程在每次通話前或位置更新前均必定會發生。
D,交換中可以定義使鑒權過程, Ciphering過程,TMSI再分配過程使他們並非每次都發生。
30、手機正在通話狀態下,它切換進入了一個新的位置區中的小區,那麼: C
A,它會通話過程中進行位置更新。
B,它會在下次跨LAC區時進行位置更新。
C,它會在通話結束後馬上進行位置更新。
31、手機正常關機後,下列那些情況是正確的: C
A,系統仍舊會通過PAGING信道對它發出PAGING請求,雖然手機已經收不到了。
B,短消息被排隊到資料庫中,如果在用戶開機前還未被更新掉,短消息也不能發送到用戶。
C,其他用戶對該手機的呼叫請求會被拒絕。
D,發給它的短消息肯定會丟失。
32、下列那些描述是正確的: D
A,每次位置更新均需牽入HLR。
B,位置更新均發生在不同的VLR上。
C,幾類位置更新的優先順序是一樣的。
D,每次位置更新中均要改動用戶數據的存放位置或指引位置。
33、下列哪種技術不屬於抵抗多徑衰落現象: b
a) 信道編碼 b) DTX c) 跳頻 d)交織
34、TMSI再分配的主要目的是: A
A,防盜打 B,加密 C,漫遊 D,IMSI數量不夠時的補充。
35、解決位置更新過多的方法有: ABD
A,重新規劃位置區 B,位置區邊界盡量避開小區重選頻繁的地段
C,給邊界處的小區多配置信令信道 D,修改CellReselectHysteresis參數四、問答題
1、請列出切換失敗的幾種原因(請至少列出三種)
(1) 硬體問題(例如時鍾板出了問題,無法同步)
(2) 原小區存在干擾導致無法解碼HANDOVER COMMAND 的信息;目標小區存在干擾
(3) 孤島效應(同BCCH,BSIC)
(4) 要切入的目標小區信道資源短缺
(5) 惡劣的無線條件導致MS無法收到原小區的切換命令或無法佔用目標小區所指配的信道(惡劣的無線條件往往是由小區之間覆蓋重疊較少引起)
(6) 覆蓋問題:目標小區與源小區沒有足夠的重疊區域
(7) 由於天線受到阻擋或同一小區的兩根天線覆蓋不均勻導致
(8) 直放站放大了雜訊
(9) 參數設置問題:如T3103設置過小,導致MS沒來得及佔用上目標小區的信道
(10) A介面負荷過大產生擁塞,導致MSC內或MSC之間傳送切換請求和切換命令時無時隙可用。
MSC的LAC表定義不全。2、移動台為空閑模式下,移動台接收到小區1和小區2的信號電平如下:
AV_RXLEV = 26 in cell 1 , AV_RXLEV = 20 in cell 2
具體參數如下:
小區 1: TXPWR_MAX_CCH = 39 dBm
RXLEV_ACCESS_MIN = 20
CELL_RESELECT_HYSTERESIS = 4dB
小區2: TXPWR_MAX_CCH = 33 dBm
RXLEV_ACCESS_MIN = 14
MS是否執行小區選擇?
a) 如果是 phase 1 MS,小區1和小區2屬於同一個位置區
b) 如果是 phase 1 MS ,小區1和小區2不屬於同一個位置區
提供以下信息:
C1 = AV_RXLEV - ACCESS_MIN - Max (0, MS_TXPWR_MAX_CCH - P)
MS GSM900 Phase 1, power class 3 = 37 dBm.
CELL 1:C1=26-20-2=4
CELL 2::C1=20-14=6
C1(CELL2)>C1(CELL1)進行小區重選
不同LAC:
當C1(CELL2)〉C1(CELL1)+ CELL_RESELECT_HYSTERESIS時,才進行小區重選
3、如果發現一個BS240基站宕機,而電源是好的,重新開關基站後發現基站仍然無法正常工作,試圖連接LMT也未能成功(假設LMT是好的),請分析一下,一般可能是什麼原因導致如此故障,並採取何措施進行恢復。
應為COBA負責LMT的連接功能,可能COBA損壞或備板損壞,需要更換COBA進行恢復;
4、BS240基站配置成8/8/8,硬體包括一個基本機架和兩個擴展機架。在開通過程中,發現三個機架CU模塊的創建很順利,但在創建擴展機架的DUAMCO時,總是不成功。無論嘗試多少次,系統是中提示DUAMCO的狀態是「not installed」。現假設機架的備板沒有問題,機架間相連的電纜也沒有問題。請解釋可能的原因。
ACT故障
合路器損壞
CAN BUS故障
COBA或COSA隱性故障
合路器背板故障
COBA合COSA背板故障
機櫃內部連線是否緊密選擇題
1,在GSM移動通信系統中,開放的通信介面有:(abd )
a, Air介面
b, A介面
c, A-bis介面
d, O&M介面
2,在GSM移動通信系統中,空中介面使用的協議是:( d)
a, LAPD信令 b, A-bis信令 c, CCS7信令 d, LAPDm信令
3,在呼叫時,用於進行鑒權和呼叫建立的信道有:( b )
a, FACCH
b, SDCCH
c, PCH
d, FACCH
4,鄭州市區一個GSM900的基站,可能的BCCH頻率為:( bc)
a,29
b,83
c, 96
d,1020
5,三代站基站重啟過程中BCFA板停留在0006狀態,可能的原因有:(
cd )
a,傳輸不通
b,傳輸通,但信令不活
c,信令活,下載軟體包
d,信令活,但BSC機房未加數據
6,開通三代站基站時,傳輸路由和傳輸板TRUA都沒有問題,但是基站傳輸板亮黃燈,可能的原因有:( a )
a,同步設置不正確
b,分支表設置不正確
c, TRUA跳線有問題
d,基站後背板跳線有問題
7,開通四代站基站的過程中,所有載頻停留在 狀態,可能的原因是:( cd )
a, BB2A有問題
b, BOIA有問題
c, traffic manager有問題
d, 傳輸板有問題
8,一對愛立信的微波,如果有一端的發射頻率為14930.00,那麼對端的發射頻率應該為( a )
a,14510.00
b,15350
c,13920.00
d,15940.00
9,開通一個微蜂窩基站,其傳輸從一個宏蜂窩基站做交叉連接分時隙並經過微波,開通之後本站載頻能夠工作,但是出2993告警,撥測無法佔用戶,可能的原因:( d )
a,微波故障 b,宏蜂窩基站傳輸板故障 c,微蜂窩基站傳輸板故障 d,宏蜂窩基站交叉連接故障
10,一個NOKIA微波,其電源指示燈亮黃燈,可能的故障原因有:(ad )
a,時鍾未校準
b,饋線和室外單元故障
c,2M中斷
d,2M通路環路
11,下列那些單元可以生成13M時鍾:( ac)
a, BCFA
b, MCLG
c, BOIA
d, VXTA
12,某個三代站載頻TRXA不能夠執行調頻功能,可能的故障點在:(a )
a, BB部分
b, TX部分
c, RX部分
d, MCLG部分
H. java面試題及答案
阿里巴巴的.
I. Java基礎面試題都有哪些
1.java異常機制的原理與應用
答:每當程序出現異常之後,如果程序沒有進行相應的處理,則程序會出現中斷現象。
實際上,產生了異常之後,JVM會拋出一個異常類的實例化對象,如果此時使用了try語句捕獲的話,則可以進行異常的處理,否則,交給JVM進行處理。當try語句捕獲異常之後,將與catch語句的異常類型進行匹配,如果匹配成功則執行catch內的語句。簡單的應用:在所以throws語句的地方加入try-catch。標准應用:try-catch-finally-throw-throws一起使用。
2. 垃圾回收機制的優點
答:釋放無用的對象所佔用的空間。方式:自動回收,手動回收。使用System.gc(),實際上調用Runtime.getRuntime().gc()
3. Error與Exception區別
答:Error是jvm進行處理,是jvm出錯
exception是可以由程序處理的,可以用try-catch捕獲的
4. final,finally,finallize
答:final定義的變數的值不能改變,定義的方法不能被覆蓋,定義的類不能被繼承
finally是異常的統一出口,finallize是垃圾回收前的收尾工作,是Object類定義的
5. Anonymous Inner Class是否可以extends,是否可以implements Interface
答:允許繼承和實現,因為匿名內部類就是在抽象類和介面的基礎上發展起來的
6. Static Nested Class 與Inner Class的區別
答:使用Static定義的Class就是外部類,可以通過外部類. 內部類直接訪問
而Inner Class是不能被外部訪問的,只能通過外部類的實例再找到內部類實例。
7. HashMap and HashTable?
答:HashMap:1) released in jdk 1.2,new Class 2)採用非同步處理方式,性能較高,是非線程安全的 3)允許null
HashTable:
1)released in jdk 1.0 ,old Class
2)採用同步處理方式,性能低,是線程安全的
3)不允許null
8. assert代表什麼?
答:asserts是jdk 1.4之後發布的新關鍵字,表示斷言,即程序執行到某個地方肯定是預計的值,一般開發很少使用。要使用assert,必須加上 -ea參數
9. gc是什麼?
答:gc是garbage collection,垃圾回收,使用gc可以進行垃圾空間的釋放
10. String s = new String("xyz")產生了幾個對象?
答:一個匿名對象xyz,在棧空間內。一個new實例化的對象,在堆空間內。
11. sleep() and wait()?
答:sleep()是Thread類定義方法,表示線程的休眠,可以自動喚醒
wait()方法是Object類定義的方法,需要手動notify()和notifyAll()//sleep()不釋放資源,wait()釋放資源
12. Overload與Override的區別
答:Overload:重載
|- 在一個類中定義的若干方法
|- 所有的方法名相同,但參數類型或個數不同
|- 只有參數有關,與返回類型無關
Override:覆寫
|- 在繼承的關系中
|- 子類定義了父類同名的方法,參數類型或個數最好完全一樣。
|- 訪問許可權不能更嚴格
13. abstract class 和 interface有什麼區別?
答:抽象類:
|-由抽象方法和常量、變數、全局常量、構造方法、普通方法組成
|-使用abstract聲明
|-子類要通過extends繼承抽象類,子類如果不是抽象類,則必須覆寫抽象類的全部抽象方法
|-存在單繼承的局限
|-抽象類可以實現若干個介面
介面:
|-由抽象方法和全局常量組成
|-使用interface關鍵字
|-子類要通過implements實現介面,子類如果不是抽象類,則必須覆寫抽象類的全部抽象方法
|-一個子類可以實現多個介面
|-介面不能繼承一個抽象類,但允許繼承多個介面