真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

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

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

成都創(chuàng)新互聯(lián)公司是專業(yè)的薩爾圖網(wǎng)站建設(shè)公司,薩爾圖接單;提供成都網(wǎng)站建設(shè)、成都網(wǎng)站制作,網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行薩爾圖網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!

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

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

集合概念:

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

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

List接口:

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

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

LinkedList:雙向鏈表

Set接口:

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

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

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

Map接口:

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

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

TreeSet:樹(shù)集 內(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 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:使用增強(qiáng)for循環(huán)。 
    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:使用傳統(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)建一個(gè)HashMap對(duì)象,并加入了一些鍵值對(duì)。 
    Map maps = new HashMap(); 
    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)來(lái)遍歷map集合方法1; keySet() 
    //strongForMethod1(maps); 
    // 使用增強(qiáng)For循環(huán)來(lái)遍歷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集合中的每一個(gè)鍵值對(duì), 
  private static void traditionalMethod2(Map maps) { 
    Set> sets = maps.entrySet(); 
    // 取得迭代器遍歷出對(duì)應(yīng)的值。 
    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集合中的所有鍵,遍歷鍵取得所對(duì)應(yīng)的值。 
  private static void traditionalMethod1(Map maps) { 
    Set sets = maps.keySet(); 
    // 取得迭代器遍歷出對(duì)應(yīng)的值。 
    Iterator it = sets.iterator(); 
    while (it.hasNext()) { 
      String key = it.next(); 
      String value = maps.get(key); 
      System.out.println(key + " : " + value); 
    } 
  } 
} 

感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!


本文題目:詳解Java中l(wèi)ist,set,map的遍歷與增強(qiáng)for循環(huán)
本文URL:http://weahome.cn/article/psocjp.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部