當前位置:才華齋>計算機>計算機二級>

最新2016年Java精選面試題

計算機二級 閱讀(1.91W)

很多小夥伴畢業在即,找工作和麵試又被提上了日程,為了解決小夥伴們的燃眉之急。下面是本站小編為大家搜尋整理的關於最新2016年Java精選面試題,歡迎參考練習,希望你喜歡!想了解更多相關資訊請持續關注我們應屆畢業生考試網!

最新2016年Java精選面試題

  Switch能否用string做引數?

1、在 Java 7 之前, switch 只能支援byte,short,char,int 或者其對應的封裝類以及 Enum 型別。在JAVA 7中,String 支援被加上了。

  equals與==的區別:

1、==是判斷兩個變數或例項是不是指向同一個記憶體空間

2、equals是判斷兩個變數或例項所指向的記憶體空間的值是不是相同

  Object有哪些公用方法?

1、方法equals測試的是兩個物件是否相等

2、方法clone進行物件拷貝

3、方法getClass返回和當前物件相關的Class物件

4、方法notify,notifyall,wait都是用來對給定物件進行執行緒同步

  Java的四種引用,強弱軟虛,用到的場景

1、強引用:如果一個物件具有強引用,它就不會被垃圾回收器回收。即使當前記憶體空間不足,JVM也不會回收它,而是丟擲 OutOfMemoryError 錯誤,使程式異常終止。如果想中斷強引用和某個物件之間的關聯,可以顯式地將引用賦值為null,這樣一來的話,JVM在合適的時間就會回收該物件

2、軟引用:在使用軟引用時,如果記憶體的空間足夠,軟引用就能繼續被使用,而不會被垃圾回收器回收,只有在記憶體不足時,軟引用才會被垃圾回收器回收。

3、弱引用:具有弱引用的物件擁有的生命週期更短暫。因為當 JVM 進行垃圾回收,一旦發現弱引用物件,無論當前記憶體空間是否充足,都會將弱引用回收。不過由於垃圾回收器是一個優先順序較低的執行緒,所以並不一定能迅速發現弱引用物件

4、虛引用:顧名思義,就是形同虛設,如果一個物件僅持有虛引用,那麼它相當於沒有引用,在任何時候都可能被垃圾回收器回收。

  Hashcode的作用,與 equal 有什麼區別

1、同樣用於鑑定2個物件是否相等的,java集合中有 list 和 set 兩類,其中 set不允許元素重複實現,那個這個不允許重複實現的方法,如果用 equal 去比較的話,如果存在1000個元素,你 new 一個新的元素出來,需要去呼叫1000次 equal 去逐個和他們比較是否是同一個物件,這樣會大大降低效率。hashcode實際上是返回物件的`儲存地址,如果這個位置上沒有元素,就把元素直接儲存在上面,如果這個位置上已經存在元素,這個時候才去呼叫equal方法與新元素進行比較,相同的話就不存了,雜湊到其他地址上

  String、StringBuffer與StringBuilder的區別

1、String 型別和 StringBuffer 型別的主要效能區別其實在於 String 是不可變的物件

2、StringBuffer和StringBuilder底層是 char[]陣列實現的

3、StringBuffer是執行緒安全的,而StringBuilder是執行緒不安全的

  Override和Overload的含義去區別

1、Overload顧名思義是重新載入,它可以表現類的多型性,可以是函式裡面可以有相同的函式名但是引數名、返回值、型別不能相同;或者說可以改變引數、型別、返回值但是函式名字依然不變。

2、就是ride(重寫)的意思,在子類繼承父類的時候子類中可以定義某方法與其父類有相同的名稱和引數,當子類在呼叫這一函式時自動呼叫子類的方法,而父類相當於被覆蓋(重寫)了。

  抽象類和介面的區別

1、一個類只能繼承單個類,但是可以實現多個介面

2、介面強調特定功能的實現,而抽象類強調所屬關係

3、抽象類中的所有方法並不一定要是抽象的,你可以選擇在抽象類中實現一些基本的方法。而介面要求所有的方法都必須是抽象的

  解析XML的幾種方式的原理與特點:DOM、SAX、PULL

1、DOM:消耗記憶體:先把xml文件都讀到記憶體中,然後再用DOM API來訪問樹形結構,並獲取資料。這個寫起來很簡單,但是很消耗記憶體。要是資料過大,手機不夠牛逼,可能手機直接宕機

2、SAX:解析效率高,佔用記憶體少,基於事件驅動的:更加簡單地說就是對文件進行順序掃描,當掃描到文件(document)開始與結束、元素(element)開始與結束、文件(document)結束等地方時通知事件處理函式,由事件處理函式做相應動作,然後繼續同樣的掃描,直至文件結束。

3、SAX:與 SAX 類似,也是基於事件驅動,我們可以呼叫它的next()方法,來獲取下一個解析事件(就是開始文件,結束文件,開始標籤,結束標籤),當處於某個元素時可以呼叫XmlPullParser的getAttributte()方法來獲取屬性的值,也可呼叫它的nextText()獲取本節點的值。

  wait()和sleep()的區別

1、sleep來自Thread類,和wait來自Object類

2、呼叫sleep()方法的過程中,執行緒不會釋放物件鎖。而 呼叫 wait 方法執行緒會釋放物件鎖

3、sleep睡眠後不出讓系統資源,wait讓出系統資源其他執行緒可以佔用CPU

4、sleep(milliseconds)需要指定一個睡眠時間,時間一到會自動喚醒

  JAVA多型的實現原理

1、抽象的來講,多型的意思就是同一訊息可以根據傳送物件的不同而採用多種不同的行為方式。(傳送訊息就是函式呼叫)

2、實現的原理是動態繫結,程式呼叫的方法在執行期才動態繫結,追溯原始碼可以發現,JVM 通過引數的自動轉型來找到合適的辦法。

  JAVA 中堆和棧的區別,說下java 的記憶體機制

1、基本資料型別比變數和物件的引用都是在棧分配的

2、堆記憶體用來存放由new建立的物件和陣列

3、類變數(static修飾的變數),程式在一載入的時候就在堆中為類變數分配記憶體,堆中的記憶體地址存放在棧中

4、例項變數:當你使用java關鍵字new的時候,系統在堆中開闢並不一定是連續的空間分配給變數,是根據零散的堆記憶體地址,通過雜湊演算法換算為一長串數字以表徵這個變數在堆中的"物理位置”,例項變數的生命週期--當例項變數的引用丟失後,將被GC(垃圾回收器)列入可回收“名單”中,但並不是馬上就釋放堆中記憶體

5、區域性變數: 由宣告在某方法,或某程式碼段裡(比如for迴圈),執行到它的時候在棧中開闢記憶體,當局部變數一但脫離作用域,記憶體立即釋放

  講講 Java 中的集合有多少種,區別是什麼?

1、ArrayList、LinkedList、Vector的區別:ArrayList 和Vector底層是採用陣列方式儲存資料,Vector由於使用了synchronized方法(執行緒安全)所以效能上比ArrayList要差,LinkedList使用雙向連結串列實現儲存,隨機存取比較慢

2、HashMap的底層原始碼實現:當我們往HashMap中put元素的時候,先根據key的hashCode重新計算hash值,根據hash值得到這個元素在陣列中的位置(即下標),如果陣列該位置上已經存放有其他元素了,那麼在這個位置上的元素將以連結串列的形式存放,新加入的放在鏈頭,最先加入的放在鏈尾。如果陣列該位置上沒有元素,就直接將該元素放到此陣列中的該位置上。

3、Fail-Fast機制:在使用迭代器的過程中有其他執行緒修改了map,那麼將丟擲ConcurrentModificationException,這就是所謂fail-fast機制。這一機制在原始碼中的實現是通過modCount域,modCount顧名思義就是修改次數,對HashMap內容的修改都將增加這個值,那麼在迭代器初始化過程中會將這個值賦給迭代器的expectedModCount。在迭代過程中,判斷modCount跟expectedModCount是否相等,如果不相等就表示已經有其他執行緒修改了Map.