亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java Collections集合繼承結構圖_動力節點Java學院整理

發布時間:2020-09-30 06:24:21 來源:腳本之家 閱讀:189 作者:mrr 欄目:編程語言

面向對象語言對事物的體現都是以對象的形式,所以為了方便對多個對象的操作,就對對象進行存儲,集合就是存儲對象最常用的一種方式。

數組雖然也可以存儲對象,但長度是固定的;集合長度是可變的,數組中可以存儲基本數據類型,集合只能存儲對象。
集合類的特點:集合只用于存儲對象,集合長度是可變的,集合可以存儲不同類型的對象。 

集合框架圖  

Java Collections集合繼承結構圖_動力節點Java學院整理

Java Collections集合繼承結構圖_動力節點Java學院整理

Collection (集合的最大接口)繼承關系

  ——List 可以存放重復的內容
  ——Set  不能存放重復的內容,所以的重復內容靠hashCode()和equals()兩個方法區分
  ——Queue  隊列接口
  ——SortedSet  可以對集合中的數據進行排序

Collection定義了集合框架的共性功能。

1,添加

add(e);
addAll(collection);

2,刪除

remove(e);
removeAll(collection);
clear();

3,判斷。

contains(e);
isEmpty();

4,獲取

iterator();
size();

5,獲取交集。

retainAll();

6,集合變數組。

toArray();

*add方法的參數類型是Object。以便于接收任意類型對象。
*集合中存儲的都是對象的引用(地址)

List的常用子類

List:

特有方法。凡是可以操作角標的方法都是該體系特有的方法。


add(index,element);
addAll(index,Collection);


remove(index);


set(index,element);


get(index):
subList(from,to);
listIterator();
int indexOf(obj):獲取指定元素的位置。
ListIterator listIterator();
——ArrayList   線程不安全,查詢速度快
——Vector  線程安全,但速度慢,已被ArrayList替代
——LinkedList  鏈表結果,增刪速度快

Set接口

Set:元素是無序(存入和取出的順序不一定一致),元素不可以重復。

|——HashSet:底層數據結構是哈希表。是線程不安全的。不同步。

  HashSet是如何保證元素唯一性的呢?

  是通過元素的兩個方法,hashCode和equals來完成。

  如果元素的HashCode值相同,才會判斷equals是否為true。

  如果元素的hashcode值不同,不會調用equals。

  注意,對于判斷元素是否存在,以及刪除等操作,依賴的方法是元素的hashcode和equals方法。

——TreeSet:

有序的存放:TreeSet  線程不安全,可以對Set集合中的元素進行排序

通過compareTo或者compare方法來保證元素的唯一性,元素以二叉樹的形式存放。

集合的輸出

4種常見的輸出方式

  ——Iterator: 迭代輸出,使用最多的輸出方式
  ——ListIterator: Iterator的子接口,專門用于輸出List中的內容
  ——Enumeration
  ——foreach

在迭代時,不可以通過集合對象的方法操作集合中的元素。

因為會發生ConcurrentModificationException異常。

所以,在迭代器時,只能用迭代器的放過操作元素,可是Iterator方法是有限的,

只能對元素進行判斷,取出,刪除的操作,

如果想要其他的操作如添加,修改等,就需要使用其子接口,ListIterator。

該接口只能通過List集合的listIterator方法獲取。

Map接口

Correction、Set、List接口都屬于單值的操作,而Map中的每個元素都使用key——>value的形式存儲在集合中。

Map集合:該集合存儲鍵值對。一對一對往里存。而且要保證鍵的唯一性。

1,添加。

put(K key, V value)
putAll(Map<? extends K,? extends V> m)

2,刪除。

clear()
remove(Object key)

3,判斷。

containsValue(Object value)
containsKey(Object key)
isEmpty()

4,獲取。

get(Object key)
size()
values()
entrySet()
keySet()

8、Map接口的常用子類

Map

|HashMap:底層是哈希表數據結構,允許使用 null 值和 null 鍵,該集合是不同步的。將hashtable替代,jdk1.2.效率高。

|--TreeMap:底層是二叉樹數據結構。線程不同步。可以用于給map集合中的鍵進行排序。

集合工具類

Collections:集合框架的工具類。里面定義的都是靜態方法。

Collections和Collection有什么區別?

Collection是集合框架中的一個頂層接口,它里面定義了單列集合的共性方法。

它有兩個常用的子接口,

List:對元素都有定義索引。有序的。可以重復元素。

Set:不可以重復元素。無序。

Collections是集合框架中的一個工具類。該類中的方法都是靜態的

提供的方法中有可以對list集合進行排序,二分查找等方法。

通常常用的集合都是線程不安全的。因為要提高效率。

如果多線程操作這些集合時,可以通過該工具類中的同步方法,將線程不安全的集合,轉換成安全的。

以上所述是小編給大家介紹的Java Collections集合繼承結構圖_動力節點Java學院整理,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

兴义市| 浏阳市| 滨海县| 双桥区| 腾冲县| 隆安县| 合肥市| 黄陵县| 丰都县| 镶黄旗| 沈丘县| 三都| 安远县| 华宁县| 灵石县| 通化县| 临桂县| 大足县| 兴山县| 恩施市| 济南市| 南昌县| 高要市| 吉首市| 泸水县| 鄂托克旗| 洪江市| 花垣县| 汝州市| 鄂托克前旗| 宁阳县| 潍坊市| 肥西县| 涞水县| 剑川县| 海兴县| 福州市| 黄石市| 永安市| 云梦县| 满城县|