亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

首頁 Java Java面試題 幾乎所有Java面試都會(huì)問到的問題:說ArrayList和LinkedList的差別

幾乎所有Java面試都會(huì)問到的問題:說ArrayList和LinkedList的差別

Jul 26, 2023 pm 03:11 PM
java java面試題

前言

大家好,我是你們的老朋友青戈,知道你們想我了,所以我又來了?

Java的資料結(jié)構(gòu)是面試考察的重點(diǎn),只要參與過Java面試的同學(xué)相信都有所體會(huì)。面試官問這類問題的時(shí)候往往是想檢視你是否研究過Java中常用資料類型的底層結(jié)構(gòu),而不是只是簡單的停留在"會(huì)使用"的層次。那麼在面試的過程中我們要如何把這個(gè)問題說好,讓面試官滿意呢?

本期我將針對Java高頻考點(diǎn)ArrayList和LinkedList的原理進(jìn)行分析,希望能幫助你。

ArrayList和LinkedList簡介

ArrayList底層是一個(gè)Object類型的數(shù)組,初始容量是10,支援動(dòng)態(tài)擴(kuò)容,擴(kuò)容後的容量是目前容量的1.5倍,它的最大容量是Integer.MAX_VALUE - 8(但是仍可以擴(kuò)容到Integer.MAX_VALUE),對於空出的8位,目前的解釋是避免一些機(jī)器記憶體溢出,減少出錯(cuò)幾率

LinkedList底層是雙向鍊錶,初始容量是0,擴(kuò)容只需新建節(jié)點(diǎn)進(jìn)行指標(biāo)指向即可。

為了簡化成口頭可表述的語言,方便同學(xué)們在面試的時(shí)候向面試官解釋,我這裡就不貼源碼輔助說明了,有興趣的同學(xué)可以自己翻源碼看看內(nèi)部的構(gòu)造和方法,加深對這塊的理解。

區(qū)別

  • # ArrayList隨機(jī)存取效率很高,因?yàn)樵氐膬Υ媸怯行虻?,透過下標(biāo)index可以知道所查詢資料在記憶體中的位置,尋址快,時(shí)間複雜度O(1);
  • #LinkedList查詢效率較低,它在查詢指定資料的時(shí)候需要遍歷鍊錶逐一查詢,時(shí)間複雜度O(n)。

插入

  • ArrayList在尾部插入的效率比較高,時(shí)間複雜度O(1),但在其他位置插入效率則比較低,需要進(jìn)行大量的資料移動(dòng),時(shí)間複雜度O(n);
  • #LinkedList在頭部和尾部插入元素的效率比較高,時(shí)間複雜度為O(1),但在中間指定位置插入元素,需要先遍歷找到元素的位置,再插入,時(shí)間複雜度O(n)。

刪除

  • #ArrayList移除元素除了結(jié)尾節(jié)點(diǎn)之外都伴隨著需要進(jìn)行大量的資料移動(dòng),時(shí)間複雜度O(n);
  • LinkedList刪除元素效率相對較高,只需要改變指標(biāo)的指向,但是刪除元素需要遍歷查詢出資料的位置,時(shí)間複雜度O (n)。

記憶體空間

  • #ArrayList基於數(shù)組實(shí)現(xiàn),每次擴(kuò)容後容量是固定的,所以在尾部會(huì)預(yù)留一部分的空間;
  • LinkedList是基於雙向鍊錶實(shí)現(xiàn),所以每個(gè)節(jié)點(diǎn)除了保存資料之外還需要保存前後節(jié)點(diǎn)的指針,會(huì)消耗一部分空間。

擴(kuò)充機(jī)制

  • #ArrayList每次擴(kuò)容需要把原數(shù)組的元素複製到新的陣列裡面去;
  • LinkedList是鍊錶,不存在擴(kuò)容的說法。

相同點(diǎn)

執(zhí)行緒安全性

#

ArrayList和LinkedList都是線程不安全的,多線程環(huán)境下容易造成髒讀的問題,可以使用Collections.synchronizedList()方法保證線程的安全性

#儲存特點(diǎn)

儲存的元素都是有順序的,都是可以重複的,新增元素都是儲存到List的結(jié)尾處。

以上是幾乎所有Java面試都會(huì)問到的問題:說ArrayList和LinkedList的差別的詳細(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 教程
1597
29
PHP教程
1488
72
VSCODE設(shè)置。 JSON位置 VSCODE設(shè)置。 JSON位置 Aug 01, 2025 am 06:12 AM

settings.json文件位於用戶級或工作區(qū)級路徑,用於自定義VSCode設(shè)置。 1.用戶級路徑:Windows為C:\Users\\AppData\Roaming\Code\User\settings.json,macOS為/Users//Library/ApplicationSupport/Code/User/settings.json,Linux為/home//.config/Code/User/settings.json;2.工作區(qū)級路徑:項(xiàng)目根目錄下的.vscode/settings

如何使用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的掌握依賴注入春季和Guice 在Java的掌握依賴注入春季和Guice Aug 01, 2025 am 05:53 AM

依賴性(di)IsadesignpatternwhereObjectsReceivedenciesenciesExtern上,推廣looseSecouplingAndEaseerTestingThroughConstructor,setter,orfieldInjection.2.springfraMefringframeWorkSannotationsLikeLikeLike@component@component,@component,@service,@autowiredwithjava-service和@autowiredwithjava-ligatiredwithjava-lase-lightike

如何使用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虛擬機(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

Google Chrome無法打開本地文件 Google Chrome無法打開本地文件 Aug 01, 2025 am 05:24 AM

ChromecanopenlocalfileslikeHTMLandPDFsbyusing"Openfile"ordraggingthemintothebrowser;ensuretheaddressstartswithfile:///;2.SecurityrestrictionsblockAJAX,localStorage,andcross-folderaccessonfile://;usealocalserverlikepython-mhttp.server8000tor

比較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

See all articles