Java集合的總體框架相關知識總結
一、集合概述
數組其實就是一個集合。集合實際上就是一個容器??梢詠砣菁{其它的數據。
二、集合在開發(fā)中的應用
集合是一個容器,是一個載體,可以一次容納多個對象。在實際開發(fā)中,假設連接數據庫,數據庫當中有10條記錄,那么假設把這10條記錄查詢出來,在Java程序中會將10條數據封裝成10個Java對象,然后將10個Java對象放到某一個集合當中,將集合傳到前端,然后遍歷集合,將一個數據一個數據展現出來
三、集合存儲的數據
- Java集合中實際存放的只是對象的引用,每個集合元素都是一個引用變量,實際內容都放在堆內存或者方法區(qū)里面,但是基本數據類型是在棧內存上分配空間的,棧上的數據隨時就會被收回的。
- 可以通過包裝類把基本類型轉為對象類型,存放引用就可以解決這個問題。更方便的,由于有了自動拆箱和裝箱功能,基本數據類型和其對應對象(包裝類)之間的轉換變得很方便,想把基本數據類型存入集合中,直接存就可以了,系統(tǒng)會自動將其裝箱成封裝類,然后加入到集合當中

注意:
- 集合在Java中本身是一個容器,是一個對象
- 集合中任何時候存儲的都是“引用”
- 集合里面存儲的是對象內存地址
- 集合里面可以套集合
- 集合也是一個對象,也有內存地址

在Java中每一個不同的集合,底層會對應不同的數據結構。往不同的集合中存儲元素,等于將數據放到了不同的數據結構當中。什么是數據結構?數據存儲的結構就是數據結構。不同的數據結構,數據存儲方式不同。
比如
- 數組
- 二叉樹
- 鏈表
- 哈希表…
以上這些都是常用的數據結構
你往集合c1中存放數據,可能是放到數組上了。
你往集合c2中存放數據,可能是放到二叉樹上了。
…
你使用不同的集合等同于使用了不同的數據結構。new不同的對象,就是使用不同的數據結構。如果對集合用法不了解,多去查JDK的API和百度
- new ArrayList(); 創(chuàng)建一個集合,底層是數組
- new LinkedList(); 創(chuàng)建一盒集合對象,底層是鏈表
- new TreeSet(); 創(chuàng)建一個集合對象,底層是二叉樹
四、集合的包
所有的集合類和集合接口都在Java.util包下,Java.util.*;
五、集合的兩大類
- 一類是單個方式存儲元素,單個方式存儲元素,這一類集合中超級父接口:Java.util.Collection;
- 一類是以鍵值對的方式存儲元素,以鍵值對的方式存儲元素,這一類集合中超級父接口:Java.util.Map;
Iterrator it = “Collection 對象”.iterator();
it是迭代器對象

synchronized
- 修飾一個代碼塊,被修飾的代碼塊稱為同步語句塊,其作用的范圍是大括號{}括起來的代碼,作用的對象是調用這個代碼塊的對象;
- 修飾一個方法,被修飾的方法稱為同步方法,其作用的范圍是整個方法,作用的對象是調用這個方法的對象;
- 修改一個靜態(tài)的方法,其作用的范圍是整個靜態(tài)方法,作用的對象是這個類的所有對象;
- 修改一個類,其作用的范圍是synchronized后面括號括起來的部分,作用主的對象是這個類的所有對象。
Iterable是接口
- 可迭代的,可遍歷的,所有集合元素都是可迭代的,可遍歷的
- 屬性:iterator()
Collection是接口
- collection繼承于Iterable
- 所有集合繼承Iterable的含義是:所有集合都是可迭代的
Iterator
- Iterator與Collection是關聯關系
- 集合的迭代器對象
- 屬性:hashNext(),next(),remove()…
List是接口
- List繼承于Collectionlist
- 集合元素的特點:有序可重復,存儲的元素有下標
- 有序實際上是說存進去是這個順序,取出來還是這個順序,這里的順序不是按照大小排序
- 有序是因為list集合都有下標,下標從0開始,以1遞增
ArrayList
- ArrayList繼承于ListArrayList
- 集合底層采用了數組這種數據結構
- ArrayList集合是非線程安全的
LinkedList
- LinkedList繼承于List
- LinkedList集合底層采用了雙向鏈表數據結構
Vector
- Vector繼承于List
- Vector集合底層采用了數組這種數據結構
- Vector集合是線程安全的
- Vector所有的方法都有syndronized關鍵詞修飾,所以線程安全,但是效率較低,Vector用的少
Set是接口
- Set繼承于Collection
- Set集合存儲元素特點:無序不可重復
- 無序表示存進去是這個順序,取出來就不一定是這個順序了
- Set集合中元素沒有下
- 標Set集合中的元素不能重復
HashSet
- HashSet繼承于Set
- HashSet集合在new的時候,底層實際上new了一個HashMap集合
- 向HashSet集合中存儲元素,實際上是存儲到了HashMap集合中
- HashMap集合是一個哈希表數據結構
SortedSet是接口
-SortedSet集合存儲元素的特點:無序不可重復,但是放在SortedSet集合中的元素可以自動排序
SortedSet是可排序集合。放到該集合中的元素是自動按照大小順序排序
TreeSet
- TreeSet繼承于SortedSetTreeSet
- 集合底層實際上是TreeMap
- new TreeSet集合的時候,底層實際上new了一個TreeMap集合
- 往TreeSet集合中放數據的時候,實際上是將數據放到TreeMap集合中了
- TreeMap集合底層采用了二叉樹數據結構
Map是接口
- Map集合和Collection集合沒有關系
- Map集合以key和value的這種鍵值對的存儲方式存儲元素
- key和value都是存儲Java對象的內存地址
- 所有Map集合的key特點:無序不重復
- Map集合的key和Set集合存儲元素特點相同
HashMap
- HashMap繼承于Map
- HashMap集合底層是哈希表數據結構
- 非線程安全的
- Hashable
- Hashable集合底層也是哈希表數據結
- 構線程安全,其中所有方法都帶有synchronized關鍵字,效率低
SortedMap是接口
- SortedMap集合存儲元素特點:無序不可重復
- 放在SortedMap集合key部分的元素會自動按照大小順序排序
- 稱為可排序的集合
Properties
- Properties繼承Hashable,另外Properties存儲元素的時候也是采用key和value的形式存儲k
- ey和value只支持String類型,不支持其他類型
- Properties被稱為屬性類
TreeMap
- TreeMap集合底層的數據結構是一個二叉樹
到此這篇關于Java集合的總體框架相關知識總結的文章就介紹到這了,更多相關Java集合框架內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Netty分布式ByteBuf使用subPage級別內存分配剖析
這篇文章主要為大家介紹了Netty分布式ByteBuf使用subPage級別內存分配剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-03-03
大數據 java hive udf函數的示例代碼(手機號碼脫敏)
這篇文章主要介紹了大數據 java hive udf函數(手機號碼脫敏),的相關知識,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06

