面向?qū)ο笳Z言對事物的體現(xiàn)都是以對象的形式,所以為了方便對多個對象的操作,就對對象進行存儲,集合就是存儲對象最常用的一種方式。
站在用戶的角度思考問題,與客戶深入溝通,找到鎮(zhèn)賚網(wǎng)站設(shè)計與鎮(zhèn)賚網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都做網(wǎng)站、成都網(wǎng)站建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、空間域名、網(wǎng)頁空間、企業(yè)郵箱。業(yè)務(wù)覆蓋鎮(zhèn)賚地區(qū)。數(shù)組雖然也可以存儲對象,但長度是固定的;集合長度是可變的,數(shù)組中可以存儲基本數(shù)據(jù)類型,集合只能存儲對象。
集合類的特點:集合只用于存儲對象,集合長度是可變的,集合可以存儲不同類型的對象。
集合框架圖
Collection (集合的大接口)繼承關(guān)系
——List 可以存放重復(fù)的內(nèi)容
——Set 不能存放重復(fù)的內(nèi)容,所以的重復(fù)內(nèi)容靠hashCode()和equals()兩個方法區(qū)分
——Queue 隊列接口
——SortedSet 可以對集合中的數(shù)據(jù)進行排序
Collection定義了集合框架的共性功能。
1,添加
add(e);
addAll(collection);
2,刪除
remove(e);
removeAll(collection);
clear();
3,判斷。
contains(e);
isEmpty();
4,獲取
iterator();
size();
5,獲取交集。
retainAll();
6,集合變數(shù)組。
toArray();
*add方法的參數(shù)類型是Object。以便于接收任意類型對象。
*集合中存儲的都是對象的引用(地址)
List的常用子類
List:
特有方法。凡是可以操作角標(biāo)的方法都是該體系特有的方法。
增
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 鏈表結(jié)果,增刪速度快
Set接口
Set:元素是無序(存入和取出的順序不一定一致),元素不可以重復(fù)。
|——HashSet:底層數(shù)據(jù)結(jié)構(gòu)是哈希表。是線程不安全的。不同步。
HashSet是如何保證元素唯一性的呢?
是通過元素的兩個方法,hashCode和equals來完成。
如果元素的HashCode值相同,才會判斷equals是否為true。
如果元素的hashcode值不同,不會調(diào)用equals。
注意,對于判斷元素是否存在,以及刪除等操作,依賴的方法是元素的hashcode和equals方法。
——TreeSet:
有序的存放:TreeSet 線程不安全,可以對Set集合中的元素進行排序
通過compareTo或者compare方法來保證元素的唯一性,元素以二叉樹的形式存放。
集合的輸出
4種常見的輸出方式
——Iterator: 迭代輸出,使用最多的輸出方式
——ListIterator: Iterator的子接口,專門用于輸出List中的內(nèi)容
——Enumeration
——foreach
在迭代時,不可以通過集合對象的方法操作集合中的元素。
因為會發(fā)生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:底層是哈希表數(shù)據(jù)結(jié)構(gòu),允許使用 null 值和 null 鍵,該集合是不同步的。將hashtable替代,jdk1.2.效率高。
|--TreeMap:底層是二叉樹數(shù)據(jù)結(jié)構(gòu)。線程不同步??梢杂糜诮omap集合中的鍵進行排序。
集合工具類
Collections:集合框架的工具類。里面定義的都是靜態(tài)方法。
Collections和Collection有什么區(qū)別?
Collection是集合框架中的一個頂層接口,它里面定義了單列集合的共性方法。
它有兩個常用的子接口,
List:對元素都有定義索引。有序的??梢灾貜?fù)元素。
Set:不可以重復(fù)元素。無序。
Collections是集合框架中的一個工具類。該類中的方法都是靜態(tài)的
提供的方法中有可以對list集合進行排序,二分查找等方法。
通常常用的集合都是線程不安全的。因為要提高效率。
如果多線程操作這些集合時,可以通過該工具類中的同步方法,將線程不安全的集合,轉(zhuǎn)換成安全的。
以上所述是小編給大家介紹的Java Collections集合繼承結(jié)構(gòu)圖_動力節(jié)點Java學(xué)院整理,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!