W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗(yàn)值獎勵
以下實(shí)例演示了如何遍歷從Collection接口延伸出的List、Set和以鍵值對形式作存儲的Map類型的集合,以下我們分別使用了普通for,增強(qiáng)型的 for ,iterator 等方式來遍歷集合:
/* author by w3cschool.cn Main.java */ import java.util.ArrayList; import java.util.HashSet; import java.util.Iterator; import java.util.List; import java.util.Set; public class Main { public static void main(String[] args) { // List集合的遍歷 listTest(); // Set集合的遍歷 setTest(); } private static void setTest() { Set<String> set = new HashSet<String>(); set.add("JAVA"); set.add("C"); set.add("C++"); // 重復(fù)數(shù)據(jù)添加失敗 set.add("JAVA"); set.add("JAVASCRIPT"); // 使用iterator遍歷set集合 Iterator<String> it = set.iterator(); while (it.hasNext()) { String value = it.next(); System.out.println(value); } // 使用增強(qiáng)for循環(huán)遍歷set集合 for(String s: set){ System.out.println(s); } } // 遍歷list集合 private static void listTest() { List<String> list = new ArrayList<String>(); list.add("編"); list.add("程"); list.add("獅"); list.add("m.hgci.cn"); // 使用iterator遍歷 Iterator<String> it = list.iterator(); while (it.hasNext()) { String value = it.next(); System.out.println(value); } // 使用傳統(tǒng)for循環(huán)進(jìn)行遍歷 for (int i = 0, size = list.size(); i < size; i++) { String value = list.get(i); System.out.println(value); } // 使用增強(qiáng)for循環(huán)進(jìn)行遍歷 for (String value : list) { System.out.println(value); } } }
以上代碼運(yùn)行輸出結(jié)果為:
編
程
獅
m.hgci.cn
編
程
獅
m.hgci.cn
編
程
獅
m.hgci.cn
JAVA
JAVASCRIPT
C++
C
JAVA
JAVASCRIPT
C++
C
以下實(shí)例我們使用了 HashMap 的 keySet()與entrySet()方法來遍歷集合:
/* author by w3cschool.cc Main.java */ import java.util.Map; import java.util.HashMap; import java.util.HashSet; import java.util.Iterator; import java.util.List; import java.util.Set; import java.util.Map.Entry; //增強(qiáng)For循環(huán) public class Main { public static void main(String[] args) { // 創(chuàng)建一個HashMap對象,并加入了一些鍵值對。 Map<String, String> maps = new HashMap<String, String>(); maps.put("1", "PHP"); maps.put("2", "Java"); maps.put("3", "C"); maps.put("4", "C++"); maps.put("5", "HTML"); // 傳統(tǒng)的遍歷map集合的方法1; keySet() //traditionalMethod1(maps); // 傳統(tǒng)的遍歷map集合的方法2; entrySet() //traditionalMethod2(maps); // 使用增強(qiáng)For循環(huán)來遍歷map集合方法1; keySet() //strongForMethod1(maps); // 使用增強(qiáng)For循環(huán)來遍歷map集合方法2; entrySet() strongForMethod2(maps); } private static void strongForMethod2(Map<String, String> maps) { Set<Entry<String, String>> set = maps.entrySet(); for (Entry<String, String> entry : set) { String key = entry.getKey(); String value = entry.getValue(); System.out.println(key + " : " + value); } } private static void strongForMethod1(Map<String, String> maps) { Set<String> 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<String, String> maps) { Set<Map.Entry<String, String>> sets = maps.entrySet(); // 取得迭代器遍歷出對應(yīng)的值。 Iterator<Entry<String, String>> it = sets.iterator(); while (it.hasNext()) { Map.Entry<String, String> entry = (Entry<String, String>) it.next(); String key = entry.getKey(); String value = entry.getValue(); System.out.println(key + " : " + value); } } // 使用keySet()方法,獲取maps集合中的所有鍵,遍歷鍵取得所對應(yīng)的值。 private static void traditionalMethod1(Map<String, String> maps) { Set<String> sets = maps.keySet(); // 取得迭代器遍歷出對應(yīng)的值 Iterator<String> it = sets.iterator(); while (it.hasNext()) { String key = it.next(); String value = maps.get(key); System.out.println(key + " : " + value); } } }
以上代碼運(yùn)行輸出結(jié)果為:
1 : PHP 2 : Java 3 : C 4 : C++ 5 : HTML
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: