###集合,collection , map
*Array 數(shù)組。string[] s1 = new string[3];
*存儲內(nèi)容有區(qū)別侥猩,數(shù)組可以存儲基本類型和對象類型,而集合只能存儲對象抵赢。
*數(shù)組有長度限制欺劳,固定大小的數(shù)組,集合沒有長度限制铅鲤,大小不固定划提。
*數(shù)組的存儲結構是存儲單個數(shù)據(jù)。map可以存儲key = value 建值對邢享。形成了映射關聯(lián)結構
###collection 集合
*數(shù)組轉化為集合 Arrays.asList(students);???//students是數(shù)組
*集合大小獲取使用 list.size();
*集合對象獲取??list.get(i);??//獲取集合中第一個元素
*集合轉為數(shù)組???Student[] students2 = (Student[]) sList.toArray(new Student[sList.size()]);
*集合中添加元素??list.add();
###迭代器iterator鹏往,主要用于遍歷集合
Iterator it = sList.iterator();//將集合轉化為迭代器
while (it.hasNext()) {??//判斷是否存在下一個元素
Student st = it.next(); //返回下一個元素
st.info();
}
###泛型,1.5之前集合存儲的數(shù)據(jù)會自動強轉為object類型骇塘,這樣就發(fā)生了類型的丟失伊履,造成訪問安全。?????jdk1.5后新特性款违,解決集合容器數(shù)據(jù)安全問題唐瀑,主要原理是在類聲明時通過標識表示類中的具體對象型。
//這個說明容器list中存儲學生student類型對象
List list = Arrays.asList(students);
###foreach增強型for循環(huán)??迭代容器數(shù)據(jù)
for(類型 變量:要迭代的容器){
變量操作
}
###ArrayList類型
*構建 new
*添加 add(元素)
*刪除 remove(索引)
*更新 set(索引奠货,元素)
###linkedList 對于堆棧和鏈表結構有對應的實現(xiàn)介褥,所以自身包含新方法
*堆棧結構就是典型的 FILO 先進后出的結構。 例如:彈夾,最后壓入的子彈第一個打出去柔滔。
*入棧(壓棧)方法???push
*出棧(彈棧)方法???pop
###ArrayList 適用于查詢和循環(huán)遍歷 速度很快溢陪,LinkedList 適用于插入和刪除,速度很快
###ArrayList和Vector 的區(qū)別睛廊,兩者都是通過數(shù)組實現(xiàn)的形真。不同的是Vector支持線程同步,同一時刻只能一個線程訪問超全,他是線程安全的咆霜,避免了多線程并發(fā)訪問時的數(shù)據(jù)不一致問題(臟讀寫。)嘶朱。但是同步花費代價太高蛾坯,因此比ArrayList效率低,所以基本不在使用
###set 集合接口是collection接口的子類疏遏,不允許存儲相同對象脉课,如果添加相同對象,則添加失敗财异。
*1.不保證數(shù)據(jù)存儲的有序性(就是無序的)
*2.非線程安全
*3.可以添加null到集合
###set 判斷兩個對象是否相等不是使用的 == 比較倘零,而是使用equals方法判斷。
###自定義對象判斷相等戳寸,需要重寫hashcode()和eqauls()方法
####Map 雙列 存儲 key - value 主要實現(xiàn)類hashmap
####Map 特性 呈驶, key值不允許重復存儲,可以將null作為key和value來用疫鹊,無序存儲
###2_集合框架(Map集合的功能概述)
*A:Map集合的功能概述
* a:添加功能
* V put(K key,V value):添加元素袖瞻。
* 如果鍵是第一次存儲,就直接存儲元素订晌,返回null
* 如果鍵不是第一次存在虏辫,就用值把以前的值替換掉,返回以前的值
* b:刪除功能
* void clear():移除所有的鍵值對元素
* V remove(Object key):根據(jù)鍵刪除鍵值對元素锈拨,并把值返回
* c:判斷功能
* boolean containsKey(Object key):判斷集合是否包含指定的鍵
* boolean containsValue(Object value):判斷集合是否包含指定的值
* boolean isEmpty():判斷集合是否為空
* d:獲取功能
* Set> entrySet():
* V get(Object key):根據(jù)鍵獲取值
* Set keySet():獲取集合中所有鍵的集合
* Collection values():獲取集合中所有值的集合
* e:長度功能
* int size():返回集合中的鍵值對的個數(shù)
###3_集合框架(Map集合的遍歷之鍵找值)
*A:鍵找值思路:
* 獲取所有鍵的集合
* 遍歷鍵的集合,獲取到每一個鍵
* 根據(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();????????????????????//獲取集合中的每一個元素,其實就是雙列集合中的鍵
Integer value = hm.get(key);????????????//根據(jù)鍵獲取值
System.out.println(key + "=" + value);????//打印鍵值對
}*/
for(String key : hm.keySet()) {????????????????//增強for循環(huán)迭代雙列集合第一種方式
System.out.println(key + "=" + hm.get(key));
}