天天看點

java集合for循環_詳解Java中list,set,map的周遊與增強for循環

詳解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);

}

}

}

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支援!