6個月面試遇到的高頻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來對給定的對象集合進行排序。

以上就是本文的全部內容,希望對大家的學習有所幫助

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章