【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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...