參考原文
一 java集合類(lèi)簡(jiǎn)介
1、java集合大致可以分為Set窍侧、List、Queue械哟、Map四類(lèi)疏之。
Set:代表無(wú)序殿雪、不可重復(fù)的集合
List:代表有序暇咆、可以重復(fù)的集合
Map:代表具有映射關(guān)系的集合
Queue:代表一種隊(duì)列集合實(shí)現(xiàn)(java5增加)
2、java集合和數(shù)組的區(qū)別
2.1數(shù)組長(zhǎng)度在初始化時(shí)指定丙曙,而集合可以保存數(shù)量不確定的數(shù)據(jù)爸业。同時(shí)可以保存具有關(guān)聯(lián)關(guān)系的數(shù)據(jù)
2.2數(shù)組元素既可以是基本類(lèi)型的值,也可以是對(duì)象亏镰。集合里只能保存對(duì)象扯旷。
3、java集合類(lèi)之間的繼承關(guān)系
java集合類(lèi)主要由兩個(gè)派生而出collection和map
二索抓、collection接口
Collection接口是Set钧忽,Queue,List的父接口逼肯。
2.1.接口中定義的方法
添加耸黑、刪除元素,返回Collection集合的個(gè)數(shù)以及清空集合等
2.2.使用iterator遍歷集合元素
iterator就是迭代器篮幢,它是Collection接口的父接口大刊。主要用于遍歷集合中的元素,主要有兩個(gè)方法:
hasNext和next
//創(chuàng)建集合三椿,添加元素Collectiondays=newArrayList();for(inti=0;i<10;i++){Dayday=newDay(i,i*60,i*3600);days.add(day);}//獲取days集合的迭代器Iteratoriterator=days.iterator();while(iterator.hasNext()){//判斷是否有下一個(gè)元素Daynext=iterator.next();//取出該元素//逐個(gè)遍歷缺菌,取得元素后進(jìn)行后續(xù)操作.....
**注意:**當(dāng)使用Iterator對(duì)集合元素進(jìn)行迭代時(shí)葫辐,Iterator并不是把集合元素本身傳給了迭代變量,而是把集合元素的值傳給了迭代變量(就如同參數(shù)傳遞是值傳遞伴郁,基本數(shù)據(jù)類(lèi)型傳遞的是值耿战,引用類(lèi)型傳遞的僅僅是對(duì)象的引用變量),所以修改迭代變量的值對(duì)集合元素本身沒(méi)有任何影響焊傅。
2.3.Set集合
####簡(jiǎn)介?
Set集合與Collection集合基本相同昆箕,沒(méi)有提供任何額外的方法。實(shí)際上Set就是Collection租冠,只是Set不能含有重復(fù)的元素鹏倘。如果試圖把兩個(gè)相同的元素加入到同一個(gè)Set中,則會(huì)提示加入失敗顽爹,且不會(huì)被加入
2.4.List集合
List集合代表一個(gè)有序纤泵、可重復(fù)的集合。集合中的每一個(gè)元素都有其對(duì)應(yīng)的順序索引镜粤。
接口中定義的方法:
void add(int index, Object element):在列表的指定位置插入指定元素(可選操作)捏题。 **boolean addAll(int index, Collection c) : ** 將集合c 中的所有元素都插入到列表中的指定位置index處。 **Object get(index):**返回列表中指定位置的元素肉渴。int indexOf(Object o):返回此列表中第一次出現(xiàn)的指定元素的索引公荧;如果此列表不包含該元素,則返回 -1同规。 **int lastIndexOf(Object o):**返回此列表中最后出現(xiàn)的指定元素的索引循狰;如果列表不包含此元素,則返回 -1券勺。 **Object remove(int index): ** 移除列表中指定位置的元素绪钥。 **Object set(int index, Object element):**用指定元素替換列表中指定位置的元素。 **List subList(int fromIndex, int toIndex): **返回列表中指定的 fromIndex(包括 )和 toIndex(不包括)之間的所有集合元素組成的子集关炼。Object[] toArray():返回按適當(dāng)順序包含列表中的所有元素的數(shù)組(從第一個(gè)元素到最后一個(gè)元素)程腹。
除此之外,Java 8還為L(zhǎng)ist接口添加了如下兩個(gè)默認(rèn)方法儒拂。
**void replaceAll(UnaryOperator operator):**根據(jù)operator指定的計(jì)算規(guī)則重新設(shè)置List集合的所有元素寸潦。 **void sort(Comparator c):**根據(jù)Comparator參數(shù)對(duì)List集合的元素排序。
2.5.Queue集合
Queue是模擬隊(duì)列這種數(shù)據(jù)結(jié)構(gòu)社痛,隊(duì)列通常是指先進(jìn)先出(first-in-first-out)的容器见转。
接口中定義的方法:
2.6.Map
map是具有映射關(guān)系的數(shù)據(jù),因此map集合中保存著兩組數(shù)據(jù)褥影,一組保存map里面的key池户,另一組保存map里面的value,key和value都可以是任何引用類(lèi)型的數(shù)據(jù)。map中的key不允許重復(fù)校焦,value可以重復(fù)赊抖。如下圖所訴,key和value之間是一一對(duì)應(yīng)的關(guān)系寨典。
Map其實(shí)就是就類(lèi)似key數(shù)組是一個(gè)set集合氛雪,value數(shù)組是一個(gè)list集合,接口中的方法如下:
Map中還包括一個(gè)內(nèi)部Entry耸成,該類(lèi)封裝了一個(gè)key-value對(duì)报亩,包含了以下方法: