- 相關(guān)推薦
java面試題集2017
在2017年,Java面試者要提前了解面試題目,那么有哪些Java面試題呢?下面陽光網(wǎng)小編已經(jīng)為你們整理了2017java面試題集,希望可以幫到你。
2017java面試題集1
1.Java的HashMap是如何工作的?
HashMap是一個(gè)針對數(shù)據(jù)結(jié)構(gòu)的鍵值,每個(gè)鍵都會(huì)有相應(yīng)的值,關(guān)鍵是識別這樣的值。
HashMap 基于 hashing 原理,我們通過 put ()和 get ()方法儲(chǔ)存和獲取對象。當(dāng)我們將鍵值對傳遞給 put ()方法時(shí),它調(diào)用鍵對象的 hashCode ()方法來計(jì)算 hashcode,讓后找到 bucket 位置來儲(chǔ)存值對象。當(dāng)獲取對象時(shí),通過鍵對象的 equals ()方法找到正確的鍵值對,然后返回值對象。HashMap 使用 LinkedList 來解決碰撞問題,當(dāng)發(fā)生碰撞了,對象將會(huì)儲(chǔ)存在 LinkedList 的下一個(gè)節(jié)點(diǎn)中。 HashMap 在每個(gè) LinkedList 節(jié)點(diǎn)中儲(chǔ)存鍵值對對象。
2.什么是快速失敗的故障安全迭代器?
快速失敗的Java迭代器可能會(huì)引發(fā)ConcurrentModifcationException在底層集合迭代過程中被修改。故障安全作為發(fā)生在實(shí)例中的一個(gè)副本迭代是不會(huì)拋出任何異常的?焖偈〉墓收习踩独x了當(dāng)遭遇故障時(shí)系統(tǒng)是如何反應(yīng)的。例如,用于失敗的快速迭代器ArrayList和用于故障安全的迭代器ConcurrentHashMap。
3.Java BlockingQueue是什么?
Java BlockingQueue是一個(gè)并發(fā)集合util包的一部分。BlockingQueue隊(duì)列是一種支持操作,它等待元素變得可用時(shí)來檢索,同樣等待空間可用時(shí)來存儲(chǔ)元素。
4.什么時(shí)候使用ConcurrentHashMap?
在問題2中我們看到ConcurrentHashMap被作為故障安全迭代器的一個(gè)實(shí)例,它允許完整的并發(fā)檢索和更新。當(dāng)有大量的并發(fā)更新時(shí),ConcurrentHashMap此時(shí)可以被使用。這非常類似于Hashtable,但ConcurrentHashMap不鎖定整個(gè)表來提供并發(fā),所以從這點(diǎn)上ConcurrentHashMap的'性能似乎更好一些。所以當(dāng)有大量更新時(shí)ConcurrentHashMap應(yīng)該被使用。
5.哪一個(gè)List實(shí)現(xiàn)了最快插入?
LinkedList和ArrayList是另個(gè)不同變量列表的實(shí)現(xiàn)。ArrayList的優(yōu)勢在于動(dòng)態(tài)的增長數(shù)組,非常適合初始時(shí)總長度未知的情況下使用。LinkedList的優(yōu)勢在于在中間位置插入和刪除操作,速度是最快的。
LinkedList實(shí)現(xiàn)了List接口,允許null元素。此外LinkedList提供額外的get,remove,方法在LinkedList的首部或尾部。這些操作使LinkedList可被用作堆棧(stack),隊(duì)列(queue)或雙向隊(duì)列(deque)。
ArrayList實(shí)現(xiàn)了可變大小的數(shù)組。它允許所有元素,包括null。 每個(gè)ArrayList實(shí)例都有一個(gè)容量(Capacity),即用于存儲(chǔ)元素的數(shù)組的大小。這個(gè)容量可隨著不斷添加新元素而自動(dòng)增加,但是增長算法并沒有定義。當(dāng)需要插入大量元素時(shí),在插入前可以調(diào)用ensureCapacity方法來增加ArrayList的容量以提高插入效率。
2017java面試題集2
1.Iterator和ListIterator的區(qū)別
●ListIterator有add()方法,可以向List中添加對象,而Iterator不能。
●ListIterator和Iterator都有hasNext()和next()方法,可以實(shí)現(xiàn)順序向后遍歷,但是ListIterator有hasPrevious()和previous()方法,可以實(shí)現(xiàn)逆向(順序向前)遍歷。Iterator就不可以。
●ListIterator可以定位當(dāng)前的索引位置,nextIndex()和previousIndex()可以實(shí)現(xiàn)。Iterator沒有此功能。
●都可實(shí)現(xiàn)刪除對象,但是ListIterator可以實(shí)現(xiàn)對象的修改,set()方法可以實(shí)現(xiàn)。Iierator僅能遍歷,不能修改。
2.什么是CopyOnWriteArrayList,它與ArrayList有何不同?
CopyOnWriteArrayList是ArrayList的一個(gè)線程安全的變體,其中所有可變操作(add、set等等)都是通過對底層數(shù)組進(jìn)行一次新的復(fù)制來實(shí)現(xiàn)的。相比較于ArrayList它的寫操作要慢一些,因?yàn)樗枰獙?shí)例的.快照。
CopyOnWriteArrayList中寫操作需要大面積復(fù)制數(shù)組,所以性能肯定很差,但是讀操作因?yàn)椴僮鞯膶ο蠛蛯懖僮鞑皇峭粋(gè)對象,讀之間也不需要加鎖,讀和寫之間的同步處理只是在寫完后通過一個(gè)簡單的"="將引用指向新的數(shù)組對象上來,這個(gè)幾乎不需要時(shí)間,這樣讀操作就很快很安全,適合在多線程里使用,絕對不會(huì)發(fā)生ConcurrentModificationException ,因此CopyOnWriteArrayList適合使用在讀操作遠(yuǎn)遠(yuǎn)大于寫操作的場景里,比如緩存。
3.迭代器和枚舉之間的區(qū)別
如果面試官問這個(gè)問題,那么他的意圖一定是讓你區(qū)分Iterator不同于Enumeration的兩個(gè)方面:
●Iterator允許移除從底層集合的元素。
●Iterator的方法名是標(biāo)準(zhǔn)化的。
4.Hashmap如何同步?
當(dāng)我們需要一個(gè)同步的HashMap時(shí),有兩種選擇:
●使用Collections.synchronizedMap(..)來同步HashMap。
●使用ConcurrentHashMap的
這兩個(gè)選項(xiàng)之間的首選是使用ConcurrentHashMap,這是因?yàn)槲覀儾恍枰i定整個(gè)對象,以及通過ConcurrentHashMap分區(qū)地圖來獲得鎖。
5.IdentityHashMap和HashMap的區(qū)別
IdentityHashMap是Map接口的實(shí)現(xiàn)。不同于HashMap的,這里采用參考平等。
●在HashMap中如果兩個(gè)元素是相等的,則key1.equals(key2)
●在IdentityHashMap中如果兩個(gè)元素是相等的,則key1 == key2
2017java面試題集3
1、Java集合框架是什么?說出一些集合框架的優(yōu)點(diǎn)?
答:每種編程語言中都有集合,最初的Java版本包含幾種集合類:Vector、Stack、HashTable和Array。隨著集合的廣泛使用,Java1.2提出了囊括所有集合接口、實(shí)現(xiàn)和算法的集合框架。在保證線程安全的情況下使用泛型和并發(fā)集合類,Java已經(jīng)經(jīng)歷了很久。它還包括在Java并發(fā)包中,阻塞接口以及它們的實(shí)現(xiàn)。集合框架的部分優(yōu)點(diǎn)如下:
(1)使用核心集合類降低開發(fā)成本,而非實(shí)現(xiàn)我們自己的集合類。
(2)隨著使用經(jīng)過嚴(yán)格測試的集合框架類,代碼質(zhì)量會(huì)得到提高。
(3)通過使用JDK附帶的集合類,可以降低代碼維護(hù)成本。
(4)復(fù)用性和可操作性。
2、集合框架中的泛型有什么優(yōu)點(diǎn)?
答:Java1.5引入了泛型,所有的集合接口和實(shí)現(xiàn)都大量地使用它。泛型允許我們?yōu)榧咸峁┮粋(gè)可以容納的.對象類型,因此,如果你添加其它類型的任何元素,它會(huì)在編譯時(shí)報(bào)錯(cuò)。這避免了在運(yùn)行時(shí)出現(xiàn)ClassCastException,因?yàn)槟銓?huì)在編譯時(shí)得到報(bào)錯(cuò)信息。泛型也使得代碼整潔,我們不需要使用顯式轉(zhuǎn)換和instanceOf操作符。它也給運(yùn)行時(shí)帶來好處,因?yàn)椴粫?huì)產(chǎn)生類型檢查的字節(jié)碼指令。
3、Java集合框架的基礎(chǔ)接口有哪些?
答:Collection為集合層級的根接口。一個(gè)集合代表一組對象,這些對象即為它的元素。Java平臺(tái)不提供這個(gè)接口任何直接的實(shí)現(xiàn)。
Set是一個(gè)不能包含重復(fù)元素的集合。這個(gè)接口對數(shù)學(xué)集合抽象進(jìn)行建模,被用來代表集合,就如一副牌。
List是一個(gè)有序集合,可以包含重復(fù)元素。你可以通過它的索引來訪問任何元素。List更像長度動(dòng)態(tài)變換的數(shù)組。
Map是一個(gè)將key映射到value的對象。一個(gè)Map不能包含重復(fù)的key:每個(gè)key最多只能映射一個(gè)value。
一些其它的接口有Queue、Dequeue、SortedSet、SortedMap和ListIterator。
【java面試題集】相關(guān)文章:
java集合面試題04-04
java最新面試題04-05
java面試題匯總04-05
華為java面試題04-06
java高級面試題04-06
java面試題全集04-06
java測試面試題11-25
java基礎(chǔ)面試題04-04
java經(jīng)典面試題目12-09