国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 Java Java面試題 java容器的常見面試題

java容器的常見面試題

Dec 18, 2019 pm 03:17 PM
java

java容器的常見面試題

java 容器都有哪些? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?中排下(建議學(xué)習(xí)中:) 常見面試題

java容器的常見面試題

Collection 和 Collection

##Collection 和 Collections 有什麼不同?

java.util.Collection 是一個(gè)集合介面(集合類別的一個(gè)頂層介面)。它提供了對集合物件進(jìn)行基本操作的通用介面方法。 Collection介面在Java 類別庫中有很多具體的實(shí)作。 Collection介面的意義是為各種特定的集合提供了最大化的統(tǒng)一操作方式,其直接繼承介面有List與Set。

Collections則是集合類的一個(gè)工具類/幫助類,其中提供了一系列靜態(tài)方法,用於對集合中元素進(jìn)行排序、搜尋以及線程安全等各種操作java容器的常見面試題#List、Set、Map 之間的差異是什麼?


HashMap 和 Hashtable 有什麼不同?

hashMap去掉了HashTable 的contains方法,但加上了containsValue()和containsKey()方法。 hashTable同步的,而HashMap是非同步的,效率上比hashTable高。

hashMap允許空鍵值,而hashTable不允許。

如何決定使用 HashMap 還是 TreeMap?

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

說一下 HashMap 的實(shí)作原理?

HashMap概述: HashMap是基於哈希表的Map介面的非同步實(shí)作。此實(shí)作提供所有可選的映射操作,並允許使用null值和null鍵。此類不保證映射的順序,特別是它不保證該順序恆久不變。

HashMap的資料結(jié)構(gòu): 在java程式語言中,最基本的結(jié)構(gòu)就是兩種,一個(gè)是數(shù)組,另外一個(gè)是模擬指標(biāo)(引用),所有的資料結(jié)構(gòu)都可以用這兩個(gè)基本結(jié)構(gòu)來建構(gòu)的,HashMap也不例外。 HashMap實(shí)際上是一個(gè)「鍊錶散列」的資料結(jié)構(gòu),即數(shù)組和鍊錶的結(jié)合體。 當(dāng)我們往Hashmap中put元素時(shí),首先根據(jù)key的hashcode重新計(jì)算hash值,根據(jù)hash值得到這個(gè)元素在數(shù)組中的位置(下標(biāo)),如果該數(shù)組在該位置上已經(jīng)存放了其他元素,那麼在這個(gè)位置上的元素將以鍊錶的形式存放,新加入的放在鏈頭,最先加入的放入鏈尾.如果數(shù)組中該位置沒有元素,就直接將該元素放到數(shù)組的該位置上。

需要注意Jdk 1.8中對HashMap的實(shí)現(xiàn)做了優(yōu)化,當(dāng)鍊錶中的節(jié)點(diǎn)資料超過八個(gè)之後,該鍊錶會(huì)轉(zhuǎn)為紅黑樹來提高查詢效率,從原來的O(n)到O(logn)

說一下HashSet 的實(shí)作原理?

HashSet底層由HashMap實(shí)作HashSet的值存放在HashMap的key上

HashMap的value統(tǒng)一為PRESENT

# ArrayList 和LinkedList 的差別是什麼?

最明顯的區(qū)別是 ArrrayList底層的資料結(jié)構(gòu)是數(shù)組,支援隨機(jī)訪問,而 LinkedList 的底層資料結(jié)構(gòu)是雙向循環(huán)鍊錶,不支援隨機(jī)存取。使用下標(biāo)存取一個(gè)元素,ArrayList 的時(shí)間複雜度是 O(1),而 LinkedList 是 O(n)。

如何實(shí)作陣列和 List 之間的轉(zhuǎn)換?

List轉(zhuǎn)換成為陣列:呼叫ArrayList的toArray方法。

陣列轉(zhuǎn)換成為List:呼叫Arrays的asList方法。

ArrayList 和 Vector 的差別是什麼?

Vector是同步的,而ArrayList不是。然而,如果你尋求在迭代的時(shí)候?qū)α斜磉M(jìn)行改變,你應(yīng)該使用CopyOnWriteArrayList。?ArrayList比Vector快,它因?yàn)橛型剑粫?huì)過載。?

ArrayList比較通用,因?yàn)槲覀兛梢允褂肅ollections工具類別輕易地取得同步清單和唯讀清單。

Array 和 ArrayList 有何不同?

Array可以容納基本型別和對象,而ArrayList只能容納對象。?Array是指定大小後不可變的,而ArrayList大小是可變的。?

Array沒有提供ArrayList那麼多功能,例如addAll、removeAll和iterator等。

######在 Queue 中 poll()和 remove()有什麼不同? #########poll() 和remove() 都是從佇列中取出一個(gè)元素,但是poll() 在取得元素失敗的時(shí)候會(huì)回傳空,但remove() 失敗的時(shí)候會(huì)拋出例外。 ###

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

vector:就比arraylist多了個(gè)同步化機(jī)制(執(zhí)行緒安全性),因?yàn)樾瘦^低,現(xiàn)在已經(jīng)不太建議使用。在web應(yīng)用中,特別是前臺(tái)頁面,往往效率(頁面響應(yīng)速度)是優(yōu)先考慮的。

statck:堆疊類,先進(jìn)後出。

hashtable:就比hashmap多了個(gè)執(zhí)行緒安全。

enumeration:枚舉,相當(dāng)於迭代器。

迭代器 Iterator 是什麼?

迭代器是一種設(shè)計(jì)模式,它是一個(gè)對象,它可以遍歷並選擇序列中的對象,而開發(fā)人員不需要了解該序列的底層結(jié)構(gòu)。迭代器通常被稱為“輕量級”對象,因?yàn)閯?chuàng)建它的代價(jià)很小。

Iterator 怎麼使用?有什麼特點(diǎn)?

Java中的Iterator功能比較簡單,而且只能單向移動(dòng):

(1) 使用方法iterator()要求容器傳回一個(gè)Iterator。第一次呼叫Iterator的next()方法時(shí),它會(huì)傳回序列的第一個(gè)元素。注意:iterator()方法是java.lang.Iterable介面,被Collection繼承。

(2) 使用next()來獲得序列中的下一個(gè)元素。

(3) 使用hasNext()檢查序列中是否還有元素。

(4) 使用remove()將迭代器新回傳的元素刪除?!?/p>

Iterator是Java迭代器最簡單的實(shí)現(xiàn),為List設(shè)計(jì)的ListIterator有更多的功能,它可以從兩個(gè)方向遍歷List,也可以從List插入和刪除元素。

Iterator 和 ListIterator 有什麼不同?

Iterator可用來遍歷Set和List集合,但ListIterator只能用來遍歷List。?

Iterator對集合只能是前向遍歷,ListIterator既可以前向也可以後向。?

ListIterator實(shí)作了Iterator接口,並包含其他的功能,例如:增加元素,替換元素,取得前一個(gè)和後一個(gè)元素的索引,等等。

以上是java容器的常見面試題的詳細(xì)內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1601
29
PHP教程
1502
276
如何使用JDBC處理Java的交易? 如何使用JDBC處理Java的交易? Aug 02, 2025 pm 12:29 PM

要正確處理JDBC事務(wù),必須先關(guān)閉自動(dòng)提交模式,再執(zhí)行多個(gè)操作,最後根據(jù)結(jié)果提交或回滾;1.調(diào)用conn.setAutoCommit(false)以開始事務(wù);2.執(zhí)行多個(gè)SQL操作,如INSERT和UPDATE;3.若所有操作成功則調(diào)用conn.commit(),若發(fā)生異常則調(diào)用conn.rollback()確保數(shù)據(jù)一致性;同時(shí)應(yīng)使用try-with-resources管理資源,妥善處理異常並關(guān)閉連接,避免連接洩漏;此外建議使用連接池、設(shè)置保存點(diǎn)實(shí)現(xiàn)部分回滾,並保持事務(wù)盡可能短以提升性能。

了解Java虛擬機(jī)(JVM)內(nèi)部 了解Java虛擬機(jī)(JVM)內(nèi)部 Aug 01, 2025 am 06:31 AM

TheJVMenablesJava’s"writeonce,runanywhere"capabilitybyexecutingbytecodethroughfourmaincomponents:1.TheClassLoaderSubsystemloads,links,andinitializes.classfilesusingbootstrap,extension,andapplicationclassloaders,ensuringsecureandlazyclassloa

如何使用Java的日曆? 如何使用Java的日曆? Aug 02, 2025 am 02:38 AM

使用java.time包中的類替代舊的Date和Calendar類;2.通過LocalDate、LocalDateTime和LocalTime獲取當(dāng)前日期時(shí)間;3.使用of()方法創(chuàng)建特定日期時(shí)間;4.利用plus/minus方法不可變地增減時(shí)間;5.使用ZonedDateTime和ZoneId處理時(shí)區(qū);6.通過DateTimeFormatter格式化和解析日期字符串;7.必要時(shí)通過Instant與舊日期類型兼容;現(xiàn)代Java中日期處理應(yīng)優(yōu)先使用java.timeAPI,它提供了清晰、不可變且線

比較Java框架:Spring Boot vs Quarkus vs Micronaut 比較Java框架:Spring Boot vs Quarkus vs Micronaut Aug 04, 2025 pm 12:48 PM

前形式攝取,quarkusandmicronautleaddueTocile timeProcessingandGraalvSupport,withquarkusoftenpernperforminglightbetterine nosserless notelless centarios.2。

了解網(wǎng)絡(luò)端口和防火牆 了解網(wǎng)絡(luò)端口和防火牆 Aug 01, 2025 am 06:40 AM

NetworkPortSandFireWallsworkTogetHertoEnableCommunication whereSeringSecurity.1.NetWorkPortSareVirtualendPointSnumbered0-655 35,with-Well-with-Newonportslike80(HTTP),443(https),22(SSH)和25(smtp)sindiessingspefificservices.2.portsoperateervertcp(可靠,c

垃圾收集如何在Java工作? 垃圾收集如何在Java工作? Aug 02, 2025 pm 01:55 PM

Java的垃圾回收(GC)是自動(dòng)管理內(nèi)存的機(jī)制,通過回收不可達(dá)對象釋放堆內(nèi)存,減少內(nèi)存洩漏風(fēng)險(xiǎn)。 1.GC從根對象(如棧變量、活動(dòng)線程、靜態(tài)字段等)出發(fā)判斷對象可達(dá)性,無法到達(dá)的對像被標(biāo)記為垃圾。 2.基於標(biāo)記-清除算法,標(biāo)記所有可達(dá)對象,清除未標(biāo)記對象。 3.採用分代收集策略:新生代(Eden、S0、S1)頻繁執(zhí)行MinorGC;老年代執(zhí)行較少但耗時(shí)較長的MajorGC;Metaspace存儲(chǔ)類元數(shù)據(jù)。 4.JVM提供多種GC器:SerialGC適用於小型應(yīng)用;ParallelGC提升吞吐量;CMS降

比較Java構(gòu)建工具:Maven vs. Gradle 比較Java構(gòu)建工具:Maven vs. Gradle Aug 03, 2025 pm 01:36 PM

Gradleisthebetterchoiceformostnewprojectsduetoitssuperiorflexibility,performance,andmoderntoolingsupport.1.Gradle’sGroovy/KotlinDSLismoreconciseandexpressivethanMaven’sverboseXML.2.GradleoutperformsMaveninbuildspeedwithincrementalcompilation,buildcac

以身作則,解釋說明 以身作則,解釋說明 Aug 02, 2025 am 06:26 AM

defer用於在函數(shù)返回前執(zhí)行指定操作,如清理資源;參數(shù)在defer時(shí)立即求值,函數(shù)按後進(jìn)先出(LIFO)順序執(zhí)行;1.多個(gè)defer按聲明逆序執(zhí)行;2.常用於文件關(guān)閉等安全清理;3.可修改命名返回值;4.即使發(fā)生panic也會(huì)執(zhí)行,適合用於recover;5.避免在循環(huán)中濫用defer,防止資源洩漏;正確使用可提升代碼安全性和可讀性。

See all articles