更新時間:2019-11-28 14:53:58 來源:動力節點 瀏覽2519次
Java技術江湖里,誰人不知,誰人不曉,它的使用率非常高,使用難度卻也不大,這也導致了很多人對它不屑一顧,殊不知其中卻暗藏玄機,今天我們不妨一起來破解一下Java集合類的面試題。
面試官常用招式:
只見面試官微微一笑,拔出長劍,向你刺來,你趕緊拔劍相迎,幾招過后,你才意識到面試官使的都是虛招,只是試探你而已。
1.Java集合框架是什么?說出一些集合框架的長處?
每種編程語言中都有集合。最初的Java版本號包括幾種集合類:Vector、Stack、HashTable和Array。
隨著集合的廣泛使用。Java1.2提出了囊括全部集合接口、實現和算法的集合框架。
在保證線程安全的情況下使用泛型和并發集合類,Java已經經歷了非常久。它還包括在Java并發包中,堵塞接口以及它們的實現。
集合框架的部分長處例如以下:
(1)使用核心集合類減少開發成本,而非實現我們自己的集合類。
(2)隨著使用經過嚴格測試的集合框架類。代碼質量會得到提高。
(3)通過使用JDK附帶的集合類,能夠減少代碼維護成本。
(4)復用性和可操作性。
**********
2.集合框架中的泛型有什么長處?
Java1.5引入了泛型。全部的集合接口和實現都大量地使用它。泛型同意我們為集合提供一個能夠容納的對象類型,因此。假設你加入其他類型的不論什么元素,它會在編譯時報錯。這避免了在執行時出現ClassCastException。由于你將會在編譯時得到報錯信息。
泛型也使得代碼整潔,我們不須要使用顯式轉換和instanceOf操作符。
它也給執行時帶來長處。由于不會產生類型檢查的字節碼指令。
**********
3.Java集合框架的基礎接口有哪些?
Collection為集合層級的根接口。
一個集合代表一組對象。這些對象即為它的元素。
Java平臺不提供這個接口不論什么直接的實現。
Set是一個不能包括反復元素的集合。
這個接口對數學集合抽象進行建模。被用來代表集合,就如一副牌。
List是一個有序集合。能夠包括反復元素。
你能夠通過它的索引來訪問不論什么元素。List更像長度動態變換的數組。
Map是一個將key映射到value的對象.一個Map不能包括反復的key:每一個key最多僅僅能映射一個value。
一些其他的接口有Queue、Dequeue、SortedSet、SortedMap和ListIterator。
**********
4.為何Collection不從Cloneable和Serializable接口繼承?
Collection接口指定一組對象,對象即為它的元素。怎樣維護這些元素由Collection的詳細實現決定。
比如。一些如List的Collection實現同意反復的元素。而其他的如Set就不同意。非常多Collection實現有一個公有的clone方法。
然而。把它放到集合的全部實現中也是沒有意義的。這是由于Collection是一個抽象表現。重要的是實現。
當與詳細實現打交道的時候,克隆或序列化的語義和含義才發揮作用。所以,詳細實現應該決定怎樣對它進行克隆或序列化,或它能否夠被克隆或序列化。
在全部的實現中授權克隆和序列化,終于導致更少的靈活性和很多其他的限制。特定的實現應該決定它能否夠被克隆和序列化。
**********
5.為何Map接口不繼承Collection接口?
雖然Map接口和它的實現也是集合框架的一部分。但Map不是集合。集合也不是Map。
因此,Map繼承Collection毫無意義,反之亦然。
假設Map繼承Collection接口,那么元素去哪兒?Map包括key-value對,它提供抽取key或value列表集合的方法,可是它不適合“一組對象”規范。
**********
6.Iterator是什么?
Iterator接口提供遍歷不論什么Collection的接口。
我們能夠從一個Collection中使用迭代器方法來獲取迭代器實例。迭代器代替了Java集合框架中的Enumeration。迭代器同意調用者在迭代過程中移除元素。
**********
7.Enumeration和Iterator接口的差別?
Enumeration的速度是Iterator的兩倍,也使用更少的內存。
Enumeration是非常基礎的,也滿足了基礎的須要。可是,與Enumeration相比,Iterator更加安全,由于當一個集合正在被遍歷的時候。它會阻止其他線程去改動集合。
迭代器代替了Java集合框架中的Enumeration。
迭代器同意調用者從集合中移除元素,而Enumeration不能做到。
為了使它的功能更加清晰,迭代器方法名已經經過改善。
**********
8.為何沒有像Iterator.add()這種方法。向集合中加入元素?
語義不明。已知的是,Iterator的協議不能確保迭代的次序。然而要注意。ListIterator沒有提供一個add操作,它要確保迭代的順序。
**********
9.為何迭代器沒有一個方法能夠直接獲取下一個元素。而不須要移動游標?
它能夠在當前Iterator的頂層實現。可是它用得非常少,假設將它加到接口中,每一個繼承都要去實現它。這沒有意義。
**********
10.Iterater和ListIterator之間有什么差別?
(1)我們能夠使用Iterator來遍歷Set和List集合,而ListIterator僅僅能遍歷List。
(2)Iterator僅僅能夠向前遍歷。而LIstIterator能夠雙向遍歷。
(3)ListIterator從Iterator接口繼承,然后加入了一些額外的功能,比方加入一個元素、替換一個元素、獲取前面或后面元素的索引位置。
以上就是動力節點Java培訓機構小編介紹的“IT面試篇:Java集合類面試題”的內容,希望對大家有幫助,如有疑問,請在線咨詢,有專業老師隨時為你服務。
相關推薦
最新最全java面試題及答案(初級到高級)
0基礎 0學費 15天面授
有基礎 直達就業
業余時間 高薪轉行
工作1~3年,加薪神器
工作3~5年,晉升架構
提交申請后,顧問老師會電話與您溝通安排學習