Jdk5.0新特性:
Collection在jdk1.5以后,有了一個父接口Iterable,這個接口的出現(xiàn)的將iterator方法進(jìn)行抽取,提高了擴展性。
--------------------------------------------------
增強for循環(huán):foreach語句,foreach簡化了迭代器。
格式:// 增強for循環(huán)括號里寫兩個參數(shù),第一個是聲明一個變量,第二個就是需要迭代的容器
for( 元素類型 變量名 : Collection集合 & 數(shù)組 ) {
…
}
高級for循環(huán)和傳統(tǒng)for循環(huán)的區(qū)別:
高級for循環(huán)在使用時,必須要明確被遍歷的目標(biāo)。這個目標(biāo),可以是Collection集合或者數(shù)組,如果遍歷Collection集合,在遍歷過程中還需要對元素進(jìn)行操作,比如刪除,需要使用迭代器。
如果遍歷數(shù)組,還需要對數(shù)組元素進(jìn)行操作,建議用傳統(tǒng)for循環(huán)因為可以定義角標(biāo)通過角標(biāo)操作元素。如果只為遍歷獲取,可以簡化成高級for循環(huán),它的出現(xiàn)為了簡化書寫。
高級for循環(huán)可以遍歷map集合嗎?不可以。但是可以將map轉(zhuǎn)成set后再使用foreach語句。
1)、作用:對存儲對象的容器進(jìn)行迭代: 數(shù)組 collection map
2)、增強for循環(huán)迭代數(shù)組:
String [] arr = {"a", "b", "c"};//數(shù)組的靜態(tài)定義方式,只試用于數(shù)組首次定義的時候
for(String s : arr) {
System.out.println(s);
}
3)、單列集合 Collection:
List list = new ArrayList();
list.add("aaa");
// 增強for循環(huán), 沒有使用泛型的集合能不能使用增強for循環(huán)迭代?能
for(Object obj : list) {
String s = (String) obj;
System.out.println(s);
}
4)、雙列集合 Map:
Map map = new HashMap();
map.put("a", "aaa");
// 傳統(tǒng)方式:必須掌握這種方式
Set entrys = map.entrySet(); // 1.獲得所有的鍵值對Entry對象
iter = entrys.iterator(); // 2.迭代出所有的entry
while(iter.hasNext()) {
Map.Entry entry = (Entry) iter.next();
String key = (String) entry.getKey(); // 分別獲得key和value
String value = (String) entry.getValue();
System.out.println(key + "=" + value);
}
// 增強for循環(huán)迭代:原則上map集合是無法使用增強for循環(huán)來迭代的,因為增強for循環(huán)只能針對實現(xiàn)了Iterable接口的集合進(jìn)行迭代;Iterable是jdk5中新定義的接口,就一個方法iterator方法,只有實現(xiàn)了Iterable接口的類,才能保證一定有iterator方法,java有這樣的限定是因為增強for循環(huán)內(nèi)部還是用迭代器實現(xiàn)的,而實際上,我們可以通過某種方式來使用增強for循環(huán)。
for(Object obj : map.entrySet()) {
Map.Entry entry = (Entry) obj; // obj 依次表示Entry
System.out.println(entry.getKey() + "=" + entry.getValue());
}
5)、集合迭代注意問題:在迭代集合的過程中,不能對集合進(jìn)行增刪操作(會報并發(fā)訪問異常);可以用迭代器的方法進(jìn)行操作(子類listIterator:有增刪的方法)。
6)、增強for循環(huán)注意問題:在使用增強for循環(huán)時,不能對元素進(jìn)行賦值;
int[] arr = {1,2,3};
for(int num : arr) {
num = 0; //不能改變數(shù)組的值
}
System.out.println(arr[1]); //2
可變參數(shù)(...):用到函數(shù)的參數(shù)上,當(dāng)要操作的同一個類型元素個數(shù)不確定的時候,可是用這個方式,這個參數(shù)可以接受任意個數(shù)的同一類型的數(shù)據(jù)。
和以前接收數(shù)組不一樣的是:
以前定義數(shù)組類型,需要先創(chuàng)建一個數(shù)組對象,再將這個數(shù)組對象作為參數(shù)傳遞給函數(shù)?,F(xiàn)在,直接將數(shù)組中的元素作為參數(shù)傳遞即可。底層其實是將這些元素進(jìn)行數(shù)組的封裝,而這個封裝動作,是在底層完成的,被隱藏了。所以簡化了用戶的書寫,少了調(diào)用者定義數(shù)組的動作。
如果在參數(shù)列表中使用了可變參數(shù),可變參數(shù)必須定義在參數(shù)列表結(jié)尾(也就是必須是最后一個參數(shù),否則編譯會失敗。)。
如果要獲取多個int數(shù)的和呢?可以使用將多個int數(shù)封裝到數(shù)組中,直接對數(shù)組求和即可。
---------------------------------------------------
靜態(tài)導(dǎo)入:導(dǎo)入了類中的所有靜態(tài)成員,簡化靜態(tài)成員的書寫。
import static java.util.Collections.*; //導(dǎo)入了Collections類中的所有靜態(tài)成員