Java 實例 - 集合遍歷
阿新 • • 發佈:2018-05-02
HA rgs 類型 bsp .com imp value list hset
List與Set類型集合的遍歷
1 import java.util.ArrayList; 2 import java.util.HashSet; 3 import java.util.Iterator; 4 import java.util.List; 5 import java.util.Set; 6 7 public class Main { 8 9 public static void main(String[] args) { 10 // List集合的遍歷 11 listTest(); 12 // Set集合的遍歷 13 setTest();14 } 15 16 private static void setTest() { 17 Set<String> set = new HashSet<String>(); 18 set.add("JAVA"); 19 set.add("C"); 20 set.add("C++"); 21 // 重復數據添加失敗 22 set.add("JAVA"); 23 set.add("JAVASCRIPT"); 24 25 // 使用iterator遍歷set集合 26 Iterator<String> it = set.iterator();27 while (it.hasNext()) { 28 String value = it.next(); 29 System.out.println(value); 30 } 31 32 // 使用增強for循環遍歷set集合 33 for(String s: set){ 34 System.out.println(s); 35 } 36 } 37 38 // 遍歷list集合 39 private static void listTest() { 40List<String> list = new ArrayList<String>(); 41 list.add("W"); 42 list.add("M"); 43 list.add("L"); 44 list.add("D"); 45 list.add("www.pekst.com"); 46 47 // 使用iterator遍歷 48 Iterator<String> it = list.iterator(); 49 while (it.hasNext()) { 50 String value = it.next(); 51 System.out.println(value); 52 } 53 54 // 使用傳統for循環進行遍歷 55 for (int i = 0, size = list.size(); i < size; i++) { 56 String value = list.get(i); 57 System.out.println(value); 58 } 59 60 // 使用增強for循環進行遍歷 61 for (String value : list) { 62 System.out.println(value); 63 } 64 } 65 }
關於Map類型集合的遍歷
以下實例我們使用了 HashMap 的 keySet()與entrySet()方法來遍歷集合:
1 import java.util.Map; 2 import java.util.HashMap; 3 import java.util.HashSet; 4 import java.util.Iterator; 5 import java.util.List; 6 import java.util.Set; 7 import java.util.Map.Entry; 8 9 //增強For循環 10 public class Main { 11 12 public static void main(String[] args) { 13 // 創建一個HashMap對象,並加入了一些鍵值對。 14 Map<String, String> maps = new HashMap<String, String>(); 15 maps.put("1", "PHP"); 16 maps.put("2", "Java"); 17 maps.put("3", "C"); 18 maps.put("4", "C++"); 19 maps.put("5", "HTML"); 20 21 // 傳統的遍歷map集合的方法1; keySet() 22 //traditionalMethod1(maps); 23 // 傳統的遍歷map集合的方法2; entrySet() 24 //traditionalMethod2(maps); 25 // 使用增強For循環來遍歷map集合方法1; keySet() 26 //strongForMethod1(maps); 27 // 使用增強For循環來遍歷map集合方法2; entrySet() 28 strongForMethod2(maps); 29 } 30 31 private static void strongForMethod2(Map<String, String> maps) { 32 Set<Entry<String, String>> set = maps.entrySet(); 33 for (Entry<String, String> entry : set) { 34 String key = entry.getKey(); 35 String value = entry.getValue(); 36 System.out.println(key + " : " + value); 37 } 38 } 39 40 private static void strongForMethod1(Map<String, String> maps) { 41 Set<String> set = maps.keySet(); 42 for (String s : set) { 43 String key = s; 44 String value = maps.get(s); 45 System.out.println(key + " : " + value); 46 } 47 } 48 49 // 使用entrySet()方法,獲取maps集合中的每一個鍵值對, 50 private static void traditionalMethod2(Map<String, String> maps) { 51 Set<Map.Entry<String, String>> sets = maps.entrySet(); 52 // 取得叠代器遍歷出對應的值。 53 Iterator<Entry<String, String>> it = sets.iterator(); 54 while (it.hasNext()) { 55 Map.Entry<String, String> entry = (Entry<String, String>) it.next(); 56 String key = entry.getKey(); 57 String value = entry.getValue(); 58 System.out.println(key + " : " + value); 59 } 60 } 61 62 // 使用keySet()方法,獲取maps集合中的所有鍵,遍歷鍵取得所對應的值。 63 private static void traditionalMethod1(Map<String, String> maps) { 64 Set<String> sets = maps.keySet(); 65 // 取得叠代器遍歷出對應的值 66 Iterator<String> it = sets.iterator(); 67 while (it.hasNext()) { 68 String key = it.next(); 69 String value = maps.get(key); 70 System.out.println(key + " : " + value); 71 } 72 } 73 }
Java 實例 - 集合遍歷