欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于Java集合框架面試題(含答案)下

 更新時(shí)間:2015年12月15日 10:33:07   作者:cricode  
Java集合框架為Java編程語(yǔ)言的基礎(chǔ),也是Java面試中很重要的一個(gè)知識(shí)點(diǎn)。這里,我列出了一些關(guān)于Java集合的重要問(wèn)題和答案。

21.HashMap和HashTable有何不同?

(1)HashMap允許key和value為null,而HashTable不允許。

(2)HashTable是同步的,而HashMap不是。所以HashMap適合單線程環(huán)境,HashTable適合多線程環(huán)境。

(3)在Java1.4中引入了LinkedHashMap,HashMap的一個(gè)子類,假如你想要遍歷順序,你很容易從HashMap轉(zhuǎn)向LinkedHashMap,但是HashTable不是這樣的,它的順序是不可預(yù)知的。

(4)HashMap提供對(duì)key的Set進(jìn)行遍歷,因此它是fail-fast的,但HashTable提供對(duì)key的Enumeration進(jìn)行遍歷,它不支持fail-fast。

(5)HashTable被認(rèn)為是個(gè)遺留的類,如果你尋求在迭代的時(shí)候修改Map,你應(yīng)該使用CocurrentHashMap。

22.如何決定選用HashMap還是TreeMap?

對(duì)于在Map中插入、刪除和定位元素這類操作,HashMap是最好的選擇。然而,假如你需要對(duì)一個(gè)有序的key集合進(jìn)行遍歷,TreeMap是更好的選擇?;谀愕腸ollection的大小,也許向HashMap中添加元素會(huì)更快,將map換為TreeMap進(jìn)行有序key的遍歷。

23.ArrayList和Vector有何異同點(diǎn)?

ArrayList和Vector在很多時(shí)候都很類似。

(1)兩者都是基于索引的,內(nèi)部由一個(gè)數(shù)組支持。

(2)兩者維護(hù)插入的順序,我們可以根據(jù)插入順序來(lái)獲取元素。

(3)ArrayList和Vector的迭代器實(shí)現(xiàn)都是fail-fast的。

(4)ArrayList和Vector兩者允許null值,也可以使用索引值對(duì)元素進(jìn)行隨機(jī)訪問(wèn)。

以下是ArrayList和Vector的不同點(diǎn)。

(1)Vector是同步的,而ArrayList不是。然而,如果你尋求在迭代的時(shí)候?qū)α斜磉M(jìn)行改變,你應(yīng)該使用CopyOnWriteArrayList。

(2)ArrayList比Vector快,它因?yàn)橛型?,不?huì)過(guò)載。

(3)ArrayList更加通用,因?yàn)槲覀兛梢允褂肅ollections工具類輕易地獲取同步列表和只讀列表。

24.Array和ArrayList有何區(qū)別?什么時(shí)候更適合用Array?

Array可以容納基本類型和對(duì)象,而ArrayList只能容納對(duì)象。

Array是指定大小的,而ArrayList大小是固定的。

Array沒(méi)有提供ArrayList那么多功能,比如addAll、removeAll和iterator等。盡管ArrayList明顯是更好的選擇,但也有些時(shí)候Array比較好用。

(1)如果列表的大小已經(jīng)指定,大部分情況下是存儲(chǔ)和遍歷它們。

(2)對(duì)于遍歷基本數(shù)據(jù)類型,盡管Collections使用自動(dòng)裝箱來(lái)減輕編碼任務(wù),在指定大小的基本類型的列表上工作也會(huì)變得很慢。

(3)如果你要使用多維數(shù)組,使用[][]比List<List<>>更容易。

25.ArrayList和LinkedList有何區(qū)別?

ArrayList和LinkedList兩者都實(shí)現(xiàn)了List接口,但是它們之間有些不同。

(1)ArrayList是由Array所支持的基于一個(gè)索引的數(shù)據(jù)結(jié)構(gòu),所以它提供對(duì)元素的隨機(jī)訪問(wèn),復(fù)雜度為O(1),但LinkedList存儲(chǔ)一系列的節(jié)點(diǎn)數(shù)據(jù),每個(gè)節(jié)點(diǎn)都與前一個(gè)和下一個(gè)節(jié)點(diǎn)相連接。所以,盡管有使用索引獲取元素的方法,內(nèi)部實(shí)現(xiàn)是從起始點(diǎn)開始遍歷,遍歷到索引的節(jié)點(diǎn)然后返回元素,時(shí)間復(fù)雜度為O(n),比ArrayList要慢。

(2)與ArrayList相比,在LinkedList中插入、添加和刪除一個(gè)元素會(huì)更快,因?yàn)樵谝粋€(gè)元素被插入到中間的時(shí)候,不會(huì)涉及改變數(shù)組的大小,或更新索引。

(3)LinkedList比ArrayList消耗更多的內(nèi)存,因?yàn)長(zhǎng)inkedList中的每個(gè)節(jié)點(diǎn)存儲(chǔ)了前后節(jié)點(diǎn)的引用。

26.哪些集合類提供對(duì)元素的隨機(jī)訪問(wèn)?

ArrayList、HashMap、TreeMap和HashTable類提供對(duì)元素的隨機(jī)訪問(wèn)。

27.EnumSet是什么?

java.util.EnumSet是使用枚舉類型的集合實(shí)現(xiàn)。當(dāng)集合創(chuàng)建時(shí),枚舉集合中的所有元素必須來(lái)自單個(gè)指定的枚舉類型,可以是顯示的或隱示的。EnumSet是不同步的,不允許值為null的元素。它也提供了一些有用的方法,比如copyOf(Collection c)、of(E first,E…rest)和complementOf(EnumSet s)。

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

Vector、HashTable、Properties和Stack是同步類,所以它們是線程安全的,可以在多線程環(huán)境下使用。Java1.5并發(fā)API包括一些集合類,允許迭代時(shí)修改,因?yàn)樗鼈兌脊ぷ髟诩系目寺∩希运鼈冊(cè)诙嗑€程環(huán)境中是安全的。

29.并發(fā)集合類是什么?

Java1.5并發(fā)包(java.util.concurrent)包含線程安全集合類,允許在迭代時(shí)修改集合。迭代器被設(shè)計(jì)為fail-fast的,會(huì)拋出ConcurrentModificationException。一部分類為:CopyOnWriteArrayList、 ConcurrentHashMap、CopyOnWriteArraySet。

30.BlockingQueue是什么?

Java.util.concurrent.BlockingQueue是一個(gè)隊(duì)列,在進(jìn)行檢索或移除一個(gè)元素的時(shí)候,它會(huì)等待隊(duì)列變?yōu)榉强眨划?dāng)在添加一個(gè)元素時(shí),它會(huì)等待隊(duì)列中的可用空間。BlockingQueue接口是Java集合框架的一部分,主要用于實(shí)現(xiàn)生產(chǎn)者-消費(fèi)者模式。我們不需要擔(dān)心等待生產(chǎn)者有可用的空間,或消費(fèi)者有可用的對(duì)象,因?yàn)樗荚贐lockingQueue的實(shí)現(xiàn)類中被處理了。Java提供了集中BlockingQueue的實(shí)現(xiàn),比如ArrayBlockingQueue、LinkedBlockingQueue、PriorityBlockingQueue,、SynchronousQueue等。

31.隊(duì)列和棧是什么,列出它們的區(qū)別?

棧和隊(duì)列兩者都被用來(lái)預(yù)存儲(chǔ)數(shù)據(jù)。java.util.Queue是一個(gè)接口,它的實(shí)現(xiàn)類在Java并發(fā)包中。隊(duì)列允許先進(jìn)先出(FIFO)檢索元素,但并非總是這樣。Deque接口允許從兩端檢索元素。

棧與隊(duì)列很相似,但它允許對(duì)元素進(jìn)行后進(jìn)先出(LIFO)進(jìn)行檢索。

Stack是一個(gè)擴(kuò)展自Vector的類,而Queue是一個(gè)接口。

32.Collections類是什么?

Java.util.Collections是一個(gè)工具類僅包含靜態(tài)方法,它們操作或返回集合。它包含操作集合的多態(tài)算法,返回一個(gè)由指定集合支持的新集合和其它一些內(nèi)容。這個(gè)類包含集合框架算法的方法,比如折半搜索、排序、混編和逆序等。

33.Comparable和Comparator接口是什么?

如果我們想使用Array或Collection的排序方法時(shí),需要在自定義類里實(shí)現(xiàn)Java提供Comparable接口。Comparable接口有compareTo(T OBJ)方法,它被排序方法所使用。我們應(yīng)該重寫這個(gè)方法,如果“this”對(duì)象比傳遞的對(duì)象參數(shù)更小、相等或更大時(shí),它返回一個(gè)負(fù)整數(shù)、0或正整數(shù)。但是,在大多數(shù)實(shí)際情況下,我們想根據(jù)不同參數(shù)進(jìn)行排序。比如,作為一個(gè)CEO,我想對(duì)雇員基于薪資進(jìn)行排序,一個(gè)HR想基于年齡對(duì)他們進(jìn)行排序。這就是我們需要使用Comparator接口的情景,因?yàn)镃omparable.compareTo(Object o)方法實(shí)現(xiàn)只能基于一個(gè)字段進(jìn)行排序,我們不能根據(jù)對(duì)象排序的需要選擇字段。Comparator接口的compare(Object o1, Object o2)方法的實(shí)現(xiàn)需要傳遞兩個(gè)對(duì)象參數(shù),若第一個(gè)參數(shù)比第二個(gè)小,返回負(fù)整數(shù);若第一個(gè)等于第二個(gè),返回0;若第一個(gè)比第二個(gè)大,返回正整數(shù)。

34.Comparable和Comparator接口有何區(qū)別?

Comparable和Comparator接口被用來(lái)對(duì)對(duì)象集合或者數(shù)組進(jìn)行排序。Comparable接口被用來(lái)提供對(duì)象的自然排序,我們可以使用它來(lái)提供基于單個(gè)邏輯的排序。

Comparator接口被用來(lái)提供不同的排序算法,我們可以選擇需要使用的Comparator來(lái)對(duì)給定的對(duì)象集合進(jìn)行排序。

35.我們?nèi)绾螌?duì)一組對(duì)象進(jìn)行排序?

如果我們需要對(duì)一個(gè)對(duì)象數(shù)組進(jìn)行排序,我們可以使用Arrays.sort()方法。如果我們需要排序一個(gè)對(duì)象列表,我們可以使用Collection.sort()方法。兩個(gè)類都有用于自然排序(使用Comparable)或基于標(biāo)準(zhǔn)的排序(使用Comparator)的重載方法sort()。Collections內(nèi)部使用數(shù)組排序方法,所有它們兩者都有相同的性能,只是Collections需要花時(shí)間將列表轉(zhuǎn)換為數(shù)組。

36.當(dāng)一個(gè)集合被作為參數(shù)傳遞給一個(gè)函數(shù)時(shí),如何才可以確保函數(shù)不能修改它?

在作為參數(shù)傳遞之前,我們可以使用Collections.unmodifiableCollection(Collection c)方法創(chuàng)建一個(gè)只讀集合,這將確保改變集合的任何操作都會(huì)拋出UnsupportedOperationException。

37.我們?nèi)绾螐慕o定集合那里創(chuàng)建一個(gè)synchronized的集合?

我們可以使用Collections.synchronizedCollection(Collection c)根據(jù)指定集合來(lái)獲取一個(gè)synchronized(線程安全的)集合。

38.集合框架里實(shí)現(xiàn)的通用算法有哪些?

Java集合框架提供常用的算法實(shí)現(xiàn),比如排序和搜索。Collections類包含這些方法實(shí)現(xiàn)。大部分算法是操作List的,但一部分對(duì)所有類型的集合都是可用的。部分算法有排序、搜索、混編、最大最小值。

39.大寫的O是什么?舉幾個(gè)例子?

大寫的O描述的是,就數(shù)據(jù)結(jié)構(gòu)中的一系列元素而言,一個(gè)算法的性能。Collection類就是實(shí)際的數(shù)據(jù)結(jié)構(gòu),我們通?;跁r(shí)間、內(nèi)存和性能,使用大寫的O來(lái)選擇集合實(shí)現(xiàn)。比如:例子1:ArrayList的get(index i)是一個(gè)常量時(shí)間操作,它不依賴list中元素的數(shù)量。所以它的性能是O(1)。例子2:一個(gè)對(duì)于數(shù)組或列表的線性搜索的性能是O(n),因?yàn)槲覀冃枰闅v所有的元素來(lái)查找需要的元素。

40.與Java集合框架相關(guān)的有哪些最好的實(shí)踐?

(1)根據(jù)需要選擇正確的集合類型。比如,如果指定了大小,我們會(huì)選用Array而非ArrayList。如果我們想根據(jù)插入順序遍歷一個(gè)Map,我們需要使用TreeMap。如果我們不想重復(fù),我們應(yīng)該使用Set。

(2)一些集合類允許指定初始容量,所以如果我們能夠估計(jì)到存儲(chǔ)元素的數(shù)量,我們可以使用它,就避免了重新哈?;虼笮≌{(diào)整。

(3)基于接口編程,而非基于實(shí)現(xiàn)編程,它允許我們后來(lái)輕易地改變實(shí)現(xiàn)。

(4)總是使用類型安全的泛型,避免在運(yùn)行時(shí)出現(xiàn)ClassCastException。

(5)使用JDK提供的不可變類作為Map的key,可以避免自己實(shí)現(xiàn)hashCode()和equals()。

(6)盡可能使用Collections工具類,或者獲取只讀、同步或空的集合,而非編寫自己的實(shí)現(xiàn)。它將會(huì)提供代碼重用性,它有著更好的穩(wěn)定性和可維護(hù)性。

以上內(nèi)容全部都是針對(duì)java集合進(jìn)行的提問(wèn),認(rèn)為不錯(cuò)的朋友果斷收藏吧,大家也可以結(jié)合上一篇進(jìn)行學(xué)習(xí):關(guān)于Java集合框架面試題(含答案)上

相關(guān)文章

  • 詳解Servlet3.0新特性(從注解配置到websocket編程)

    詳解Servlet3.0新特性(從注解配置到websocket編程)

    Servlet3.0的出現(xiàn)是servlet史上最大的變革,其中的許多新特性大大的簡(jiǎn)化了web應(yīng)用的開發(fā),為廣大勞苦的程序員減輕了壓力,提高了web開發(fā)的效率。
    2017-04-04
  • Java構(gòu)建乘積數(shù)組的方法

    Java構(gòu)建乘積數(shù)組的方法

    這篇文章主要為大家詳細(xì)介紹了Java構(gòu)建乘積數(shù)組的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • java Disruptor構(gòu)建高性能內(nèi)存隊(duì)列使用詳解

    java Disruptor構(gòu)建高性能內(nèi)存隊(duì)列使用詳解

    這篇文章主要為大家介紹了java Disruptor構(gòu)建高性能內(nèi)存隊(duì)列使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • 詳解springboot啟動(dòng)時(shí)是如何加載配置文件application.yml文件

    詳解springboot啟動(dòng)時(shí)是如何加載配置文件application.yml文件

    這篇文章主要介紹了詳解springboot啟動(dòng)時(shí)是如何加載配置文件application.yml文件,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • Java并發(fā)編程之ReentrantLock實(shí)現(xiàn)原理及源碼剖析

    Java并發(fā)編程之ReentrantLock實(shí)現(xiàn)原理及源碼剖析

    ReentrantLock 是常用的鎖,相對(duì)于Synchronized ,lock鎖更人性化,閱讀性更強(qiáng),文中將會(huì)詳細(xì)的說(shuō)明,請(qǐng)君往下閱讀
    2021-09-09
  • RabbitMQ消息隊(duì)列之持久化機(jī)制詳解

    RabbitMQ消息隊(duì)列之持久化機(jī)制詳解

    這篇文章主要介紹了RabbitMQ消息隊(duì)列之持久化機(jī)制詳解,持久化,即將原本存在于內(nèi)存中的數(shù)據(jù)寫入到磁盤上永久保存數(shù)據(jù),防止服務(wù)宕機(jī)時(shí)內(nèi)存數(shù)據(jù)的丟失,Rabbitmq 的持久化分為隊(duì)列持久化、消息持久化和交換器持久化,需要的朋友可以參考下
    2023-08-08
  • jdk中動(dòng)態(tài)代理異常處理分析:UndeclaredThrowableException

    jdk中動(dòng)態(tài)代理異常處理分析:UndeclaredThrowableException

    最近在工作中遇到了報(bào)UndeclaredThrowableException的錯(cuò)誤,通過(guò)查找相關(guān)的資料,終于解決了,所以這篇文章主要給大家介紹了關(guān)于jdk中動(dòng)態(tài)代理異常處理分析:UndeclaredThrowableException的相關(guān)資料,需要的朋友可以參考下
    2018-04-04
  • spring cloud gateway網(wǎng)關(guān)路由分配代碼實(shí)例解析

    spring cloud gateway網(wǎng)關(guān)路由分配代碼實(shí)例解析

    這篇文章主要介紹了spring cloud gateway網(wǎng)關(guān)路由分配代碼實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-01-01
  • Java結(jié)構(gòu)性設(shè)計(jì)模式中的裝飾器模式介紹使用

    Java結(jié)構(gòu)性設(shè)計(jì)模式中的裝飾器模式介紹使用

    裝飾器模式又名包裝(Wrapper)模式。裝飾器模式以對(duì)客戶端透明的方式拓展對(duì)象的功能,是繼承關(guān)系的一種替代方案,本篇文章以虹貓藍(lán)兔生動(dòng)形象的為你帶來(lái)詳細(xì)講解
    2022-09-09
  • 淺談Java Fork/Join并行框架

    淺談Java Fork/Join并行框架

    這篇文章主要介紹了淺談Java Fork/Join并行框架,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09

最新評(píng)論