大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節(jié)點(diǎn)LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 學(xué)習(xí)攻略 職業(yè)指南 千道題中精選出的幾道Java集合類面試題

千道題中精選出的幾道Java集合類面試題

更新時間:2023-01-04 10:00:50 來源:動力節(jié)點(diǎn) 瀏覽1325次

在Java程序員的相關(guān)面試中,面試官必然會考核一些專業(yè)的技術(shù)知識,其中java集合類面試題是必須要做準(zhǔn)備的,集合的知識點(diǎn)是Java框架的核心,必然是重要考點(diǎn)之一,所以,熟知并掌握,對于日后我們的面試與就業(yè)來說,幫助非常的大:

java集合類面試題

1. 什么是集合

  • 集合就是一個放數(shù)據(jù)的容器,準(zhǔn)確的說是放數(shù)據(jù)對象引用的容器
  • 集合類存放的都是對象的引用,而不是對象的本身
  • 集合類型主要有3種:set(集)、list(列表)和map(映射)。

2. 集合的特點(diǎn)

集合的特點(diǎn)主要有如下兩點(diǎn):

  • 集合用于存儲對象的容器,對象是用來封裝數(shù)據(jù),對象多了也需要存儲集中式管理。
  • 和數(shù)組對比對象的大小不確定。因?yàn)榧鲜强勺冮L度的。數(shù)組需要提前定義大小

3. 集合和數(shù)組的區(qū)別

  • 數(shù)組是固定長度的;集合可變長度的。
  • 數(shù)組可以存儲基本數(shù)據(jù)類型,也可以存儲引用數(shù)據(jù)類型;集合只能存儲引用數(shù)據(jù)類型。
  • 數(shù)組存儲的元素必須是同一個數(shù)據(jù)類型;集合存儲的對象可以是不同數(shù)據(jù)類型。

4. 使用集合框架的好處

容量自增長;

  1. 提供了高性能的數(shù)據(jù)結(jié)構(gòu)和算法,使編碼更輕松,提高了程序速度和質(zhì)量;
  2. 可以方便地?cái)U(kuò)展或改寫集合,提高代碼復(fù)用性和可操作性。
  3. 通過使用JDK自帶的集合類,可以降低代碼維護(hù)和學(xué)習(xí)新API成本。

5. 常用的集合類有哪些?

Map接口和Collection接口是所有集合框架的父接口:

  • Collection接口的子接口包括:Set接口和List接口
  • Map接口的實(shí)現(xiàn)類主要有:HashMap、TreeMap、Hashtable、ConcurrentHashMap以及Properties等
  • Set接口的實(shí)現(xiàn)類主要有:HashSet、TreeSet、LinkedHashSet等
  • List接口的實(shí)現(xiàn)類主要有:ArrayList、LinkedList、Stack以及Vector等

6. List,Set,Map三者的區(qū)別?

Java 容器分為 Collection 和 Map 兩大類,Collection集合的子接口有Set、List、Queue三種子接口。我們比較常用的是Set、List,Map接口不是collection的子接口。

  • Collection集合主要有List和Set兩大接口
  1. List:一個有序(元素存入集合的順序和取出的順序一致)容器,元素可以重復(fù),可以插入多個null元素,元素都有索引。常用的實(shí)現(xiàn)類有 ArrayList、LinkedList 和 Vector。
  2. Set:一個無序(存入和取出順序有可能不一致)容器,不可以存儲重復(fù)元素,只允許存入一個null元素,必須保證元素唯一性。Set 接口常用實(shí)現(xiàn)類是 HashSet、LinkedHashSet 以及TreeSet。

Map是一個鍵值對集合,存儲鍵、值和之間的映射。 Key無序,唯一;value 不要求有序,允許重復(fù)。Map沒有繼承于Collection接口,從Map集合中檢索元素時,只要給出鍵對象,就會返回對應(yīng)的值對象。

  1. Map 的常用實(shí)現(xiàn)類:HashMap、TreeMap、HashTable、LinkedHashMap、ConcurrentHashMap

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

Vector:就比Arraylist多了個 synchronized (線程安全),因?yàn)樾瘦^低,現(xiàn)在已經(jīng)不太建議使用。

hashTable:就比hashMap多了個synchronized (線程安全),不建議使用。

ConcurrentHashMap:是Java5中支持高并發(fā)、高吞吐量的線程安全HashMap實(shí)現(xiàn)。它由Segment數(shù)組結(jié)構(gòu)和HashEntry數(shù)組結(jié)構(gòu)組成。Segment數(shù)組在ConcurrentHashMap里扮演鎖的角色,HashEntry則用于存儲鍵-值對數(shù)據(jù)。一個ConcurrentHashMap里包含一個Segment數(shù)組,Segment的結(jié)構(gòu)和HashMap類似,是一種數(shù)組和鏈表結(jié)構(gòu);一個Segment里包含一個HashEntry數(shù)組,每個HashEntry是一個鏈表結(jié)構(gòu)的元素;每個Segment守護(hù)著一個HashEntry數(shù)組里的元素,當(dāng)對HashEntry數(shù)組的數(shù)據(jù)進(jìn)行修改時,必須首先獲得它對應(yīng)的Segment鎖。(推薦使用)

8. Java集合的快速失敗機(jī)制 “fail-fast”?

是java集合的一種錯誤檢測機(jī)制,當(dāng)多個線程對集合進(jìn)行結(jié)構(gòu)上的改變的操作時,有可能會產(chǎn)生fail-fast 機(jī)制。

例如:假設(shè)存在兩個線程(線程1、線程2),線程1通過Iterator在遍歷集合A中的元素,在某個時候線程2修改了集合A的結(jié)構(gòu)(是結(jié)構(gòu)上面的修改,而不是簡單的修改集合元素的內(nèi)容),那么這個時候程序就會拋出 ConcurrentModificationException 異常,從而產(chǎn)生fail-fast機(jī)制。

原因:迭代器在遍歷時直接訪問集合中的內(nèi)容,并且在遍歷過程中使用一個 modCount 變量。集合在被遍歷期間如果內(nèi)容發(fā)生變化,就會改變modCount的值。每當(dāng)?shù)魇褂胔ashNext()/next()

遍歷下一個元素之前,都會檢測modCount變量是否為expectedmodCount值,是的話就返回遍歷;否則拋出異常,終止遍歷。

解決辦法:

在遍歷過程中,所有涉及到改變modCount值得地方全部加上synchronized。使用CopyOnWriteArrayList來替換ArrayList

以上就是“千道題中精選出的幾道Java集合類面試題”,你能回答上來嗎?如果想要了解更多的Java面試題相關(guān)內(nèi)容,可以關(guān)注動力節(jié)點(diǎn)Java官網(wǎng)。

提交申請后,顧問老師會電話與您溝通安排學(xué)習(xí)

免費(fèi)課程推薦 >>
技術(shù)文檔推薦 >>
主站蜘蛛池模板: 99热这里都是精品 | 国产成人久久精品二区三区 | 亚洲精品在线网站 | 亚洲精品日韩一区二区 | 久久99精品这里精品动漫6 | 国内主播大秀福利视频在线看 | 91视频网址入口 | 亚洲综合精品香蕉久久网97 | 国内精品日本久久久久影院 | 热热99| 99精品观看 | 久99久精品视频免费观看v | 99国产精品2018视频全部 | 日本aⅴ网站 | 99热久久只有精品6国产32 | 欧美日韩精品一区二区三区四区 | 一本伊在人香蕉线观新在线 | 热久久视久久精品18国产 | 久久天天躁夜夜躁2019 | 夜夜夜夜夜夜夜工噜噜噜 | 成年人的毛片 | 国产色在线 | 亚洲 国产色在线视频 | 欧美亚洲国产成人精品 | 欧美日韩一区二区在线观看 | 国产在线91精品入口 | 国产福利在线永久视频 | 久久伊人久久亚洲综合 | 波多野结衣一区二区在线 | 国产目拍亚洲精品一区二区三区 | 在线观看日本免费不卡 | 精品国产日韩久久亚洲 | 免费在线观看的毛片 | 男女一级特黄a大片 | 九九国产精品九九 | 免费视频亚洲 | 91亚洲免费 | 日本黄色小视频在线观看 | 久久久99精品久久久 | 一级毛片一级毛片a毛片欧美 | 久久国产精品亚洲一区二区 | 破外女出血一级毛片 |