詳解Java中list,set,map的周遊與增強for循環
Java集合類可分為三大塊,分别是從Collection接口延伸出的List、Set和以鍵值對形式作存儲的Map類型集合。
關于增強for循環,需要注意的是,使用增強for循環無法通路數組下标值,對于集合的周遊其内部采用的也是Iterator的相關方法。如果隻做簡單周遊讀取,增強for循環确實減輕不少的代碼量。
集合概念:
1.作用:用于存放對象
2.相當于一個容器,裡面包含着一組對象,其中的每個對象作為集合的一個元素出現
3.java的容器有集合類和數組,不同之處是
差別及其常用實作類
List接口:
清單有序 元素可重複
實作類:ArrayList:動态數組清單
LinkedList:雙向連結清單
Set接口:
集無序,元素不可重複
實作類:HashSet:散列集
TreeSet:樹集 内部排序
Map接口:
以鍵值對的方式存儲資料 資料-鍵不允許重複
實作類:HashSet:散列集
TreeSet:樹集 内部排序
JDK1.0出現的集合類都是線程安全的,但效率低
JDK1.2出現的集合類都不是線程安全的,但效率高
代碼示例如下:
import java.util.ArrayList;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Set;
public class ListAndSet{
public static void main(String[] args) {
setTest();
listTest();
}
// 周遊Set集合
private static void setTest() {
Set set = new HashSet();
set.add("A");
set.add("B");
set.add("C");
set.add("D");
set.add("E");
//set集合周遊方法1:使用iterator
Iterator it = set.iterator();
while (it.hasNext()) {
String value = it.next();
System.out.println(value);
}
//set集合周遊方法2:使用增強for循環。
for(String s: set){
System.out.println(s);
}
}
// 周遊list集合
private static void listTest() {
List list = new ArrayList();
list.add("111");
list.add("222");
list.add("333");
list.add("444");
list.add("555");
// 周遊方式1:使用iterator
Iterator it = list.iterator();
while (it.hasNext()) {
String value = it.next();
System.out.println(value);
}
// 周遊方法2:使用傳統for循環進行周遊。
for (int i = 0, size = list.size(); i < size; i++) {
String value = list.get(i);
System.out.println(value);
}
// 周遊方法3:使用增強for循環進行周遊。
for (String value : list) {
System.out.println(value);
}
}
}
//關于Map類型集合的周遊,keySet()與entrySet()方法
//增強For循環
public class Map{
public static void main(String[] args) {
// 建立一個HashMap對象,并加入了一些鍵值對。
Map maps = new HashMap();
maps.put("111", "111");
maps.put("222", "222");
maps.put("333", "333");
maps.put("444", "444");
maps.put("555", "555");
// 傳統的周遊map集合的方法1; keySet()
//traditionalMethod1(maps);
// 傳統的周遊map集合的方法2; entrySet()
//traditionalMethod2(maps);
// 使用增強For循環來周遊map集合方法1; keySet()
//strongForMethod1(maps);
// 使用增強For循環來周遊map集合方法2; entrySet()
strongForMethod2(maps);
}
private static void strongForMethod2(Map maps) {
Set> set = maps.entrySet();
for (Entry entry : set) {
String key = entry.getKey();
String value = entry.getValue();
System.out.println(key + " : " + value);
}
}
private static void strongForMethod1(Map maps) {
Set set = maps.keySet();
for (String s : set) {
String key = s;
String value = maps.get(s);
System.out.println(key + " : " + value);
}
}
// 使用entrySet()方法,擷取maps集合中的每一個鍵值對,
private static void traditionalMethod2(Map maps) {
Set> sets = maps.entrySet();
// 取得疊代器周遊出對應的值。
Iterator> it = sets.iterator();
while (it.hasNext()) {
Map.Entry entry = (Entry) it.next();
String key = entry.getKey();
String value = entry.getValue();
System.out.println(key + " : " + value);
}
}
// 使用keySet()方法,擷取maps集合中的所有鍵,周遊鍵取得所對應的值。
private static void traditionalMethod1(Map maps) {
Set sets = maps.keySet();
// 取得疊代器周遊出對應的值。
Iterator it = sets.iterator();
while (it.hasNext()) {
String key = it.next();
String value = maps.get(key);
System.out.println(key + " : " + value);
}
}
}
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支援!