集合

###集合,collection , map

*Array 數(shù)組。string[] s1 = new string[3];

*存儲(chǔ)內(nèi)容有區(qū)別,數(shù)組可以存儲(chǔ)基本類型和對(duì)象類型,而集合只能存儲(chǔ)對(duì)象。

*數(shù)組有長(zhǎng)度限制,固定大小的數(shù)組,集合沒有長(zhǎng)度限制,大小不固定。

*數(shù)組的存儲(chǔ)結(jié)構(gòu)是存儲(chǔ)單個(gè)數(shù)據(jù)。map可以存儲(chǔ)key = value 建值對(duì)。形成了映射關(guān)聯(lián)結(jié)構(gòu)

###collection 集合

*數(shù)組轉(zhuǎn)化為集合 Arrays.asList(students);???//students是數(shù)組

*集合大小獲取使用 list.size();

*集合對(duì)象獲取??list.get(i);??//獲取集合中第一個(gè)元素

*集合轉(zhuǎn)為數(shù)組???Student[] students2 = (Student[]) sList.toArray(new Student[sList.size()]);

*集合中添加元素??list.add();

###迭代器iterator,主要用于遍歷集合

Iterator it = sList.iterator();//將集合轉(zhuǎn)化為迭代器

while (it.hasNext()) {??//判斷是否存在下一個(gè)元素

Student st = it.next(); //返回下一個(gè)元素

st.info();

}

###泛型,1.5之前集合存儲(chǔ)的數(shù)據(jù)會(huì)自動(dòng)強(qiáng)轉(zhuǎn)為object類型,這樣就發(fā)生了類型的丟失,造成訪問安全。?????jdk1.5后新特性,解決集合容器數(shù)據(jù)安全問題,主要原理是在類聲明時(shí)通過標(biāo)識(shí)表示類中的具體對(duì)象型。

//這個(gè)說明容器list中存儲(chǔ)學(xué)生student類型對(duì)象

List list = Arrays.asList(students);

###foreach增強(qiáng)型for循環(huán)??迭代容器數(shù)據(jù)

for(類型 變量:要迭代的容器){

變量操作

}

###ArrayList類型

*構(gòu)建 new

*添加 add(元素)

*刪除 remove(索引)

*更新 set(索引,元素)

###linkedList 對(duì)于堆棧和鏈表結(jié)構(gòu)有對(duì)應(yīng)的實(shí)現(xiàn),所以自身包含新方法

*堆棧結(jié)構(gòu)就是典型的 FILO 先進(jìn)后出的結(jié)構(gòu)。 例如:彈夾,最后壓入的子彈第一個(gè)打出去。

*入棧(壓棧)方法???push

*出棧(彈棧)方法???pop

###ArrayList 適用于查詢和循環(huán)遍歷 速度很快,LinkedList 適用于插入和刪除,速度很快

###ArrayList和Vector 的區(qū)別,兩者都是通過數(shù)組實(shí)現(xiàn)的。不同的是Vector支持線程同步,同一時(shí)刻只能一個(gè)線程訪問,他是線程安全的,避免了多線程并發(fā)訪問時(shí)的數(shù)據(jù)不一致問題(臟讀寫。)。但是同步花費(fèi)代價(jià)太高,因此比ArrayList效率低,所以基本不在使用

###set 集合接口是collection接口的子類,不允許存儲(chǔ)相同對(duì)象,如果添加相同對(duì)象,則添加失敗。

*1.不保證數(shù)據(jù)存儲(chǔ)的有序性(就是無序的)

*2.非線程安全

*3.可以添加null到集合

###set 判斷兩個(gè)對(duì)象是否相等不是使用的 == 比較,而是使用equals方法判斷。

###自定義對(duì)象判斷相等,需要重寫hashcode()和eqauls()方法

####Map 雙列 存儲(chǔ) key - value 主要實(shí)現(xiàn)類hashmap

####Map 特性 , key值不允許重復(fù)存儲(chǔ),可以將null作為key和value來用,無序存儲(chǔ)

###2_集合框架(Map集合的功能概述)

*A:Map集合的功能概述

* a:添加功能

* V put(K key,V value):添加元素。

* 如果鍵是第一次存儲(chǔ),就直接存儲(chǔ)元素,返回null

* 如果鍵不是第一次存在,就用值把以前的值替換掉,返回以前的值

* b:刪除功能

* void clear():移除所有的鍵值對(duì)元素

* V remove(Object key):根據(jù)鍵刪除鍵值對(duì)元素,并把值返回

* c:判斷功能

* boolean containsKey(Object key):判斷集合是否包含指定的鍵

* boolean containsValue(Object value):判斷集合是否包含指定的值

* boolean isEmpty():判斷集合是否為空

* d:獲取功能

* Set> entrySet():

* V get(Object key):根據(jù)鍵獲取值

* Set keySet():獲取集合中所有鍵的集合

* Collection values():獲取集合中所有值的集合

* e:長(zhǎng)度功能

* int size():返回集合中的鍵值對(duì)的個(gè)數(shù)

###3_集合框架(Map集合的遍歷之鍵找值)

*A:鍵找值思路:

* 獲取所有鍵的集合

* 遍歷鍵的集合,獲取到每一個(gè)鍵

* 根據(jù)鍵找值

*B:案例演示

* Map集合的遍歷之鍵找值

HashMap hm = new HashMap<>();

hm.put("張三", 23);

hm.put("李四", 24);

hm.put("王五", 25);

hm.put("趙六", 26);

/*Set keySet = hm.keySet();????????????//獲取集合中所有的鍵

Iterator it = keySet.iterator();????//獲取迭代器

while(it.hasNext()) {????????????????????????//判斷單列集合中是否有元素

String key = it.next();????????????????????//獲取集合中的每一個(gè)元素,其實(shí)就是雙列集合中的鍵

Integer value = hm.get(key);????????????//根據(jù)鍵獲取值

System.out.println(key + "=" + value);????//打印鍵值對(duì)

}*/

for(String key : hm.keySet()) {????????????????//增強(qiáng)for循環(huán)迭代雙列集合第一種方式

System.out.println(key + "=" + hm.get(key));

}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 一、集合框架的概述 1、概述: 1、簡(jiǎn)述:所謂集合,就是為方便對(duì)多個(gè)對(duì)象的操作,對(duì)對(duì)象進(jìn)行存儲(chǔ)。集合就是存儲(chǔ)對(duì)象最...
    玉圣閱讀 596評(píng)論 0 4
  • 集合框架體系概述 為什么出現(xiàn)集合類?方便多個(gè)對(duì)象的操作,就對(duì)對(duì)象進(jìn)行存儲(chǔ),集合就是存儲(chǔ)對(duì)象最常用的一種方法. 數(shù)組...
    acc8226閱讀 921評(píng)論 0 1
  • 概述 Java集合框架由Java類庫(kù)的一系列接口、抽象類以及具體實(shí)現(xiàn)類組成。我們這里所說的集合就是把一組對(duì)象組織到...
    absfree閱讀 1,421評(píng)論 0 10
  • 集合框架的概念: 集合代表了一組對(duì)象(和數(shù)組一樣,但數(shù)組長(zhǎng)度不能變,而集合能)。Java中的集合框架定義了一套規(guī)范...
    銹色的柵欄閱讀 364評(píng)論 0 2
  • 01 拼拼豆豆 像素化你的世界 拼拼豆豆是一款經(jīng)典入門級(jí)手工,你所需要做的只需三步:數(shù)豆,放豆和燙豆。 不要小瞧這...
    一點(diǎn)點(diǎn)輕手工閱讀 3,013評(píng)論 3 14

友情鏈接更多精彩內(nèi)容