bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

JAVA中集合體系的示例分析-創(chuàng)新互聯(lián)

這篇文章給大家分享的是有關(guān)JAVA中集合體系的示例分析的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

成都創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供江夏網(wǎng)站建設(shè)、江夏做網(wǎng)站、江夏網(wǎng)站設(shè)計(jì)、江夏網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、江夏企業(yè)網(wǎng)站模板建站服務(wù),十余年江夏做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。

一、集合概況

Java是一種面向?qū)ο笳Z(yǔ)言,如果我們要針對(duì)多個(gè)對(duì)象進(jìn)行操作,那么首先必要將多個(gè)對(duì)象進(jìn)行保存起來(lái)之后,然后才能操作,那么我們肯定會(huì)想到用數(shù)組來(lái)進(jìn)行存放,但數(shù)組長(zhǎng)度固定,不能滿足變化的要求。所以,JAVA提供了集合。

數(shù)組與集合的區(qū)別:

數(shù)組:長(zhǎng)度固定、可以存放基本類型/引用類型、數(shù)組中元素的類型必須一致

集合:長(zhǎng)度可變自動(dòng)擴(kuò)容、只能存放引用類型、集合中元素類型可以不一致但一般保持一致

二、集合體系

集合作為一個(gè)容器,可以存儲(chǔ)多個(gè)元素,但是由于數(shù)據(jù)結(jié)構(gòu)的不同,java提供了多種集合類。將集合類中共性的功能,不斷向上抽取,最終形成了集合體系結(jié)構(gòu)。

數(shù)據(jù)結(jié)構(gòu):數(shù)據(jù)存儲(chǔ)的方式

Java中集合類的關(guān)系圖:

JAVA中集合體系的示例分析

JAVA中集合體系的示例分析

三、Collection【單值接口】

Collection是最基本的集合接口,一個(gè)Collection代表一組Object,即Collection的元素(Elements)。因?yàn)橐恍〤ollection允許存放相同的元素而另一些不行。一些能有序而另一些不行,于是衍生出兩個(gè)子類接口List和Set。

JAVA中集合體系的示例分析

Collection接口中常用方法:

A:添加功能
boolean add(Object obj):向集合中添加一個(gè)元素
boolean addAll(Collection c):向集合中添加一個(gè)集合的元素。
B:刪除功能
void clear():刪除集合中的所有元素。
boolean remove(Object obj):從集合中刪除指定的元素
boolean removeAll(Collection c):從集合中刪除一個(gè)指定的集合元素。
C:判斷功能
boolean isEmpty():判斷集合是否為空。
boolean contains(Object obj):判斷集合中是否存在指定的元素。
boolean containsAll(Collection c):判斷集合中是否存在指定的一個(gè)集合中的元素。
D:遍歷功能
Iterator iterator():就是用來(lái)獲取集合中每一個(gè)元素。
E:長(zhǎng)度功能
int size():獲取集合中的元素個(gè)數(shù)
F:交集功能
boolean retainAll(Collection c):判斷兩個(gè)集合中是否有相同的元素。
G:把集合轉(zhuǎn)換成數(shù)組
Object[] toArray():把集合變成數(shù)組。

List接口中常用方法:

首先我們知道List接口是Collection接口的子類,所以也具備上面的方法,但除了上面的方法外,List接口中典型的ArrayList底層是采用的數(shù)組結(jié)構(gòu),因此還具體被一些索引操作的方法,如下:

List的特有功能
A:添加功能
void add(int index, Object obj):在指定位置添加元素
B:刪除功能
Object remove(int index):根據(jù)指定索引刪除元素,并把刪除的元素返回。
C:修改功能
Object set(int index, Object obj):把指定索引位置的元素修改為指定的值,返回修改前的值。
D:獲取功能
int indexOf(Object o):返回指定元素在集合中第一次出現(xiàn)的索引
Object get(int index):獲取指定位置的元素
ListIterator listIterator():列表迭代器
E:截取功能
List subList(int fromIndex, int toIndex):截取集合。

Set接口中常用方法:

Set接口下的元素?zé)o序,不可以重復(fù)。其下面分為HashSet和TreeSet。

HashSet

底層數(shù)據(jù)結(jié)構(gòu)是哈希表,線程不安全,效率高。
保證唯一性依賴兩個(gè)方法:hashCode()和equals()。
順序:
判斷hashCode()值是否相同。
相同:繼續(xù)走equals(),看返回值
如果true:就不添加到集合。
如果false:就添加到集合。
不同:就添加到集合。

TreeSet

底層數(shù)據(jù)結(jié)構(gòu)是二叉樹(shù),線程不安全,效率高。
保證元素唯一性的方法時(shí)根據(jù)返回值是否是0。
保證排序的兩種方式:
自然排序(元素具備比較性):實(shí)現(xiàn)Comparable接口
比較器排序(集合具備比較性):實(shí)現(xiàn)Comparator接口

四、迭代器(Iterator)

迭代器,從第一張JAVA集合類圖關(guān)系中可以看出,除了中間的Collection外,置于最頂上的左邊為迭代器Iterator.

1.使用步驟:

1、通過(guò)集合對(duì)象獲取迭代器對(duì)象。
2、通過(guò)迭代器對(duì)象判斷。
3、通過(guò)迭代器對(duì)象獲取。

2.迭代器原理

由于多種集合的數(shù)據(jù)結(jié)構(gòu)不同,所以存儲(chǔ)方式不同,所以,取出方式也不同。那么這個(gè)時(shí)候,把判斷和獲取功能定義在了一個(gè)接口中,將來(lái),遍歷哪種集合的時(shí)候,只要該集合內(nèi)部實(shí)現(xiàn)這個(gè)接口即可。【迭代器模式】

3.Collection存儲(chǔ)字符串和自定義對(duì)象并通過(guò)迭代器遍歷

Collection c = new ArrayList(); 
c.add("hello"); 
c.add("world"); 
c.add("java"); 
 
Iterator it = c.iterator(); 
while(it.hasNext()) 
{ 
  String s = (String)it.next(); 
  System.out.println(s); 
}

4.ListIterator迭代器是Iterator的子接口

所以List的遍歷方式共有三種1、Iterator迭代器2、ListIterator迭代器3、普通for+get()

五、Map<鍵值對(duì)接口>

map是一個(gè)鍵值對(duì)形式的集合。它的元素都是有鍵和值組成。Map的鍵(key)是唯一的,值(value)可以重復(fù)。

JAVA中集合體系的示例分析

Map接口中常用方法:

A:添加功能
V put(K key ,V value) :當(dāng)key在集合中不存在是,添加元素;當(dāng)key存在時(shí)替換元素
B:判斷功能
boolean containsKey (Object key) :判斷指定的鍵是否在集合中存在
Boolean containsValue(Object value):判斷指定的值是否在集合中存在
Boolean isEmpty() :判斷集合是否為空
C:刪除功能
Void clear():清除所有鍵值對(duì)數(shù)據(jù)
D:獲取功能
Object get (Object key) :根據(jù)鍵獲取值
Set<K> keyset(): 所有鍵的集合
Collection<V>values() :所有值的集合
Set<Map.Entry<K,V>> entrySet() :返回此映射中包含的映射關(guān)系的 Set 視圖
E:長(zhǎng)度功能
Int size()

Map包括HashMap、HashTable和TreeMap。其中,HashTable已基本被HashMap取代, 新代碼中基本不在使用HashTable
(注:HashMap支持null , HashTable不支持null )

Map的遍歷方式:

1.鍵找值:

public static void main(String[] args) { 
  Map<String,Integer> map = new HashMap<String,Integer>(); 
  map.put("二陽(yáng)",23); 
  map.put("二崢",24); 
  map.put("二光",25); 
  Set<String> keys=map.keySet();  //把鍵其中起來(lái),存入到set集合中. 
  for(String key:keys){    //遍歷鍵集合,獲取每一個(gè)鍵。增強(qiáng)for 
   Integer value=map.get(key);  //讓鍵去找值 get(Object key) 
   System.out.println(key+"***"+value); 
  } 
}

 2.鍵值對(duì)

public static void main(String[] args) { 
  Map<String,Integer> map = new HashMap<String,Integer>(); 
  map.put("二陽(yáng)",23); 
  map.put("二崢",24); 
  map.put("二光",25); 
  Set<String> keys=map.keySet();  //把鍵其中起來(lái),存入到set集合中. 
  for(String key:keys){    //遍歷鍵集合,獲取每一個(gè)鍵。增強(qiáng)for 
   Integer value=map.get(key);  //讓鍵去找值 get(Object key) 
   System.out.println(key+"***"+value); 
  } 
}

感謝各位的閱讀!關(guān)于“JAVA中集合體系的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

分享文章:JAVA中集合體系的示例分析-創(chuàng)新互聯(lián)
文章來(lái)源:http://vcdvsql.cn/article12/dshhdc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化標(biāo)簽優(yōu)化響應(yīng)式網(wǎng)站網(wǎng)頁(yè)設(shè)計(jì)公司網(wǎng)站策劃Google

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司