【Java基礎】Java容器相關知識小結

来源:https://www.cnblogs.com/CrazyPixel/archive/2023/11/08/17818423.html
-Advertisement-
Play Games

目錄0. 前言1. Collection介面1.1. List介面1.1.1. ArrayList1.1.2. LinkedList1.1.3. Vector1.1.4. Stack1.2. Set介面1.2.1. HashSet1.2.2. LinkedHashSet1.2.3. TreeSet1 ...


目錄

0. 前言

容器,顧名思義,就是java中存儲數據的常用結構,在C++中我們接觸過數組、鏈表等等,在java中,容器則進一步規範化,形成瞭如下的容器介面繼承關係圖:

java容器主要包括collection介面(集合)和map介面(圖)

1. Collection介面

1.1. List介面

1.1.1. ArrayList

數組實現,查詢快,增刪慢,線程不安全,效率高;

1.1.2. LinkedList

鏈表實現,查詢慢,增刪快,線程不安全,效率高;

1.1.3. Vector

數組實現,查詢快,增刪慢,同步訪問

1.1.4. Stack

vector子類,先進後出,vector不常用,stack卻很常用。

1.2. Set介面

1.2.1. HashSet

基於HashMap實現,線程不安全,效率高;
存儲元素無序,不可重覆;

1.2.2. LinkedHashSet

基於LinkedHashMap實現,線程不安全,效率高;
存儲元素有序,不可重覆;

1.2.3. TreeSet

基於TreeMap實現,線程不安全,效率高;
存儲元素有序,不可重覆;

1.3. Queue介面

1.3.1. PriorityQueue

通過二叉小頂堆實現,可以用一棵完全二叉樹表示。

1.3.2. LinkedList

鏈表實現,查詢慢,增刪快,線程不安全,效率高;

2. Map介面

2.1. HashMap

數組+鏈表+紅黑樹實現,線程不安全,效率高;
重點是擴容和紅黑樹轉換

2.2. TreeMap

和HashMap無序排序不同,SortedMap介面在內部會對Key進行排序,註意到SortedMap是介面,它的實現類是TreeMap。

2.3. LinkedHashMap

底層數據結構類似hashmap,但是內部還有一個雙向鏈表維護鍵值對的順序,每個鍵值對既位於哈希表中,也位於雙向鏈表中。LinkedHashMap支持兩種順序插入順序、訪問順序。

3.常見用法——增/刪/改/查/排序/容量

以上是簡單的容器特性介紹,下麵是一些常用的容器類的使用方法,廢話不多說,上圖:

後記

如果覺得我寫得還算不錯,不妨點贊關註一波走起~
想看更多博文,請訪問我的各平臺主頁:博客園 / CSDN / 51CTO / 掘金論壇 / 知乎

參考文章

  1. Java常用容器基礎操作彙總
  2. 菜鳥教程相關文章

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文采用一張簡單的架構圖說明瞭MySQL查詢中使用的組件和組件間關係。解析了一條sql語句從客戶端請求mysql伺服器到返回給客戶端的整個生命周期流程。 ...
  • 路由跳轉原理 之 Hash 一. 路由跳轉的原理 首先講講路由跳轉的原理, 其實沒有什麼神秘的, 以變數類比: // 首先定義一個變數名為 container , 賦予初始值 'index' let container = 'index'; // 監聽一個點擊事件 window.addEventLi ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 代碼片段 閑來無事寫了個有意思的東西,滑鼠放在小方塊上會放大並擠壓周圍方塊,背景顏色會動態改變。這裡沒有用一行 js 代碼,純樣式(Sass)實現。 <template> <div class="container"> <div clas ...
  • 1. 前言 唉,好想玩滋嘣。 2. 計算屬性直接傳參接收不到 表格數據某一列需要用的計算屬性時,模板中使用計算屬性 fullName 就會直接調用 fullName 函數,而在模板中 fullName(item) 相當於fullName()(item),此處為函數柯里化。 <el-table-col ...
  • 每天,我們都在和各種文檔打交道,PRD、技術方案、個人筆記等等等。 其實文檔排版有很多學問,就像我,對排版有強迫症,見不得英文與中文之間不加空格。 所以,最近在做這麼一個谷歌擴展插件 chrome-extension-text-formatting,通過谷歌擴展,快速將選中文本,格式化為符合 中文文 ...
  • 從接觸領域驅動設計的初學階段,到實現一個舊系統改造到DDD模型,再到按DDD規範落地的3個的項目。對於領域驅動模型設計研發,從開始的各種疑惑到吸收各種先進的理念,目前在技術實施這一塊已經基本比較成熟。在既往經驗中總結了一些在開發中遇到的技術問題和解決方案進行分享。 ...
  • 目錄 事務的四大特性? 資料庫的三大範式 事務隔離級別有哪些? 生產環境資料庫一般用的什麼隔離級別呢? 編碼和字元集的關係 utf8和utf8mb4的區別 什麼是索引? 索引的優缺點? 索引的作用? 什麼情況下需要建索引? 什麼情況下不建索引? 索引的數據結構 Hash索引和B+樹索引的區別? 為什 ...
  • docker部署是主流的部署方式,極大的方便了開發部署環境,保持了環境的統一,也是實現自動化部署的前提。 1 項目的目錄結構 dist: 使用build打包命令,生成的打包目錄 npm run build : 打包項目命令 docker: 存放docker容器需要修改的配置目錄,比如 nginx配置 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...