詳解Java中l(wèi)ist,set,map的遍歷與增強(qiáng)for循環(huán)-創(chuàng)新互聯(lián)

創(chuàng)新互聯(lián)www.cdcxhl.cn八線動態(tài)BGP香港云服務(wù)器提供商,新人活動買多久送多久,劃算不套路!

創(chuàng)新互聯(lián)專注于鎮(zhèn)江企業(yè)網(wǎng)站建設(shè),自適應(yīng)網(wǎng)站建設(shè),成都商城網(wǎng)站開發(fā)。鎮(zhèn)江網(wǎng)站建設(shè)公司,為鎮(zhèn)江等地區(qū)提供建站服務(wù)。全流程按需策劃設(shè)計,專業(yè)設(shè)計,全程項目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)

詳解Java中l(wèi)ist,set,map的遍歷與增強(qiáng)for循環(huán)

Java集合類可分為三大塊,分別是從Collection接口延伸出的List、Set和以鍵值對形式作存儲的Map類型集合。

關(guān)于增強(qiáng)for循環(huán),需要注意的是,使用增強(qiáng)for循環(huán)無法訪問數(shù)組下標(biāo)值,對于集合的遍歷其內(nèi)部采用的也是Iterator的相關(guān)方法。如果只做簡單遍歷讀取,增強(qiáng)for循環(huán)確實減輕不少的代碼量。

集合概念:

1.作用:用于存放對象
2.相當(dāng)于一個容器,里面包含著一組對象,其中的每個對象作為集合的一個元素出現(xiàn)
3.java的容器有集合類和數(shù)組,不同之處是

區(qū)別及其常用實現(xiàn)類

List接口:

列表有序 元素可重復(fù)

實現(xiàn)類:ArrayList:動態(tài)數(shù)組列表

LinkedList:雙向鏈表

Set接口:

集無序,元素不可重復(fù)

實現(xiàn)類:HashSet:散列集

TreeSet:樹集 內(nèi)部排序

Map接口:

以鍵值對的方式存儲數(shù)據(jù) 數(shù)據(jù)-鍵不允許重復(fù)

實現(xiàn)類:HashSet:散列集

TreeSet:樹集 內(nèi)部排序

JDK1.0出現(xiàn)的集合類都是線程安全的,但效率低

JDK1.2出現(xiàn)的集合類都不是線程安全的,但效率高

代碼示例如下:

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<string> set = new HashSet<string>(); 
    set.add("A"); 
    set.add("B"); 
    set.add("C");  
    set.add("D"); 
    set.add("E"); 
 
    //set集合遍歷方法1:使用iterator 
    Iterator<string> it = set.iterator(); 
    while (it.hasNext()) { 
      String value = it.next(); 
      System.out.println(value); 
    } 
 
    //set集合遍歷方法2:使用增強(qiáng)for循環(huán)。 
    for(String s: set){ 
      System.out.println(s); 
    } 
  } 
 
  // 遍歷list集合 
  private static void listTest() { 
    List<string> list = new ArrayList<string>(); 
    list.add("111"); 
    list.add("222"); 
    list.add("333"); 
    list.add("444"); 
    list.add("555"); 
 
    // 遍歷方式1:使用iterator 
    Iterator<string> it = list.iterator(); 
    while (it.hasNext()) { 
      String value = it.next(); 
      System.out.println(value); 
    } 
 
    // 遍歷方法2:使用傳統(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); 
    } 
 
    // 遍歷方法3:使用增強(qiáng)for循環(huán)進(jìn)行遍歷。 
    for (String value : list) { 
      System.out.println(value); 
    } 
  } 
} 
 
//關(guān)于Map類型集合的遍歷,keySet()與entrySet()方法
//增強(qiáng)For循環(huán) 
public class Map{ 
 
  public static void main(String[] args) { 
    // 創(chuàng)建一個HashMap對象,并加入了一些鍵值對。 
    Map<string, string=""> maps = new HashMap<string, string="">(); 
    maps.put("111", "111"); 
    maps.put("222", "222"); 
    maps.put("333", "333"); 
    maps.put("444", "444"); 
    maps.put("555", "555"); 
 
    // 傳統(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); 
    } 
  } 
} 

本文標(biāo)題:詳解Java中l(wèi)ist,set,map的遍歷與增強(qiáng)for循環(huán)-創(chuàng)新互聯(lián)
文章來源:http://muchs.cn/article12/dhipgc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、云服務(wù)器定制網(wǎng)站、動態(tài)網(wǎng)站、網(wǎng)站營銷外貿(mào)建站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化