這些常見的java集合面試問題及答案,超級實用!

Java集合框架爲Java編程語言的基礎,也是Java面試中很重要的一個知識點。Java集合是java提供的工具包,包含了經常使用的數據結構:集合、鏈表、隊列、棧、數組、映射等。java

1.Java集合框架是什麼?說出一些集合框架的優勢?面試

每種編程語言中都有集合,最初的Java版本包含幾種集合類:Vector、Stack、HashTable和Array。隨着集合的普遍使用,Java1.2提出了囊括全部集合接口、實現和算法的集合框架。在保證線程安全的狀況下使用泛型和併發集合類,Java已經經歷了好久。它還包括在Java併發包中,阻塞接口以及它們的實現。集合框架的部分優勢以下:算法

(1)使用核心集合類下降開發成本,而非實現咱們本身的集合類。編程

(2)隨着使用通過嚴格測試的集合框架類,代碼質量會獲得提升。數組

(3)經過使用JDK附帶的集合類,能夠下降代碼維護成本。安全

(4)複用性和可操做性。數據結構

2.Java集合框架的基礎接口有哪些?多線程

Collection爲集合層級的根接口。一個集合表明一組對象,這些對象即爲它的元素。Java平臺不提供這個接口任何直接的實現。併發

Set是一個不能包含重複元素的集合。這個接口對數學集合抽象進行建模,被用來表明集合,就如一副牌。框架

List是一個有序集合,能夠包含重複元素。你能夠經過它的索引來訪問任何元素。List更像長度動態變換的數組。

Map是一個將key映射到value的對象.一個Map不能包含重複的key:每一個key最多隻能映射一個value。

一些其它的接口有Queue、Dequeue、SortedSet、SortedMap和ListIterator。

3.fail-fast與fail-safe有什麼區別?

Iterator的fail-fast屬性與當前的集合共同起做用,所以它不會受到集合中任何改動的影響。Java.util包中的全部集合類都被設計爲fail-fast的,而java.util.concurrent中的集合類都爲fail-safe的。Fail-fast迭代器拋出ConcurrentModificationException,而fail-safe迭代器從不拋出ConcurrentModificationException。

4.在迭代一個集合的時候,如何避免ConcurrentModificationException?

在遍歷一個集合的時候,咱們能夠使用併發集合類來避免ConcurrentModificationException,好比使用CopyOnWriteArrayList,而不是ArrayList。

5.爲什麼Iterator接口沒有具體的實現?

Iterator接口定義了遍歷集合的方法,但它的實現則是集合實現類的責任。每一個可以返回用於遍歷的Iterator的集合類都有它本身的Iterator實現內部類。

這就容許集合類去選擇迭代器是fail-fast仍是fail-safe的。好比,ArrayList迭代器是fail-fast的,而CopyOnWriteArrayList迭代器是fail-safe的。

6.UnsupportedOperationException是什麼?

UnsupportedOperationException是用於代表操做不支持的異常。在JDK類中已被大量運用,在集合框架java.util.Collections.UnmodifiableCollection將會在全部add和remove操做中拋出這個異常。

7.哪些集合類提供對元素的隨機訪問?

ArrayList、HashMap、TreeMap和HashTable類提供對元素的隨機訪問。

8.EnumSet是什麼?

java.util.EnumSet是使用枚舉類型的集合實現。當集合建立時,枚舉集合中的全部元素必須來自單個指定的枚舉類型,能夠是顯示的或隱示的。EnumSet是不一樣步的,不容許值爲null的元素。它也提供了一些有用的方法,好比copyOf(Collection c)、of(E first,E…rest)和complementOf(EnumSet s)。

9.哪些集合類是線程安全的?

Vector、HashTable、Properties和Stack是同步類,因此它們是線程安全的,能夠在多線程環境下使用。Java1.5併發API包括一些集合類,容許迭代時修改,由於它們都工做在集合的克隆上,因此它們在多線程環境中是安全的。

10.併發集合類是什麼?

Java1.5併發包(java.util.concurrent)包含線程安全集合類,容許在迭代時修改集合。迭代器被設計爲fail-fast的,會拋出ConcurrentModificationException。一部分類爲:CopyOnWriteArrayList、 ConcurrentHashMap、CopyOnWriteArraySet。

11.Comparable和Comparator接口有何區別?

Comparable和Comparator接口被用來對對象集合或者數組進行排序。Comparable接口被用來提供對象的天然排序,咱們能夠使用它來提供基於單個邏輯的排序。

Comparator接口被用來提供不一樣的排序算法,咱們能夠選擇須要使用的Comparator來對給定的對象集合進行排序。

相關文章
相關標籤/搜索