日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java Review - 集合框架=Collection+Map

發布時間:2025/3/21 java 15 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java Review - 集合框架=Collection+Map 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

  • 概述
  • 容器 = Collection + Map
  • Collection
    • Set
      • TreeSet
      • HashSet
      • LinkedHashSet
    • List
      • ArrayList
      • Vector
      • LinkedList
    • Queue
      • LinkedList
      • PriorityQueue
  • Map
    • TreeMap
    • HashMap
    • HashTable
    • LinkedHashMap


概述

容器,就是可以容納其他Java對象的對象。 Java Collections Framework(JCF) 為Java開發者提供了通用的容器。

我們知道 Java容器里只能放對象,對于基本類型(int, long, float, double等),需要將其包裝成對象類型后(Integer, Long, Float, Double等)才能放到容器里。很多時候拆箱和裝箱能夠自動完成。

這雖然會導致額外的性能和空間開銷,但簡化了設計和編程。


容器 = Collection + Map

容器主要包括 Collection 和 Map 兩種 ;

  • Collection 存儲著對象的集合
  • Map 存儲著鍵值對(兩個對象)的映射表

圖片來源: https://pierrchen.blogspot.com/2014/03/java-collections-framework-cheat-sheet.html

Collection

Set

TreeSet

基于紅黑樹實現,支持有序性操作,例如根據一個范圍查找元素的操作。

但是查找效率不如 HashSet,HashSet 查找的時間復雜度為 O(1),TreeSet 則為 O(logN)。


HashSet

基于哈希表實現,支持快速查找,但不支持有序性操作。并且失去了元素的插入順序信息,也就是說使用 Iterator 遍歷 HashSet 得到的結果是不確定的。


LinkedHashSet

具有 HashSet 的查找效率,且內部使用雙向鏈表維護元素的插入順序

List


ArrayList

基于動態數組實現,支持隨機訪問。


Vector

和 ArrayList 類似,但它是線程安全的


LinkedList

基于雙向鏈表實現,只能順序訪問,但是可以快速地在鏈表中間插入和刪除元素。不僅如此,LinkedList 還可以用作棧、隊列和雙向隊列。


Queue

LinkedList

可以用它來實現雙向隊列


PriorityQueue

基于堆結構實現,可以用它來實現優先隊列。


Map

TreeMap

基于紅黑樹實現。


HashMap


HashTable

和 HashMap 類似,但它是線程安全的,這意味著同一時刻多個線程可以同時寫入 HashTable 并且不會導致數據不一致。它是遺留類,不應該去使用它。現在可以使用 ConcurrentHashMap 來支持線程安全,并且 ConcurrentHashMap 的效率會更高,因為 ConcurrentHashMap 引入了分段鎖


LinkedHashMap

使用雙向鏈表來維護元素的順序,順序為插入順序或者最近最少使用(LRU)順序

總結

以上是生活随笔為你收集整理的Java Review - 集合框架=Collection+Map的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。