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