欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java集合框架迭代器Iterator實(shí)現(xiàn)原理解析

 更新時(shí)間:2020年08月04日 09:55:39   作者:陳彥斌  
這篇文章主要介紹了Java集合框架迭代器Iterator實(shí)現(xiàn)原理解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

使用循環(huán)遍歷集合

普通for循環(huán)

for(int i=0;i<10;i++){}

增強(qiáng)for循環(huán)

for(String str:list){}

什么是迭代器Iterator

Iterator是Java中的一個(gè)接口,核心作用就是用來(lái)遍歷容器的元素,當(dāng)容器實(shí)現(xiàn)了Iterator接口后,可以通過(guò)調(diào)用Iterator()方法獲取一個(gè)Iterator對(duì)象

為啥是調(diào)用容器里面的Iterator方法呢?

因?yàn)槿萜鞯膶?shí)現(xiàn)有多種,不同的容器遍歷規(guī)則不一樣,比如:ArrayList、LinkedList、HashSet、TreeSet等,所以設(shè)計(jì)了Iterator接口,讓容器本身去實(shí)現(xiàn)這個(gè)接口,實(shí)現(xiàn)里面的方法,從而讓開(kāi)發(fā)人員不用關(guān)心容器的遍歷機(jī)制,直接使用對(duì)應(yīng)的方法即可

三個(gè)核心方法

  • boolean hashNext():用于判斷Iterator內(nèi)是否有下個(gè)元素,如果有則返回true,沒(méi)有則false
  • Object next():返回Iterator的下一個(gè)元素,同時(shí)指針也會(huì)向后移動(dòng)一位
  • void remove():刪除指針的上一個(gè)元素(建議使用自己容器里的方法)
  public static void testSet() {
    Set<String> set = new HashSet<>();
    set.add("jack");
    set.add("tom");
    set.add("marry");
    set.add("tony");
    set.add("jack");
    Iterator<String> iterator = set.iterator();
    while (iterator.hasNext()) {
      String str = iterator.next();
      System.out.println(str);
    }
  }

  public static void testList() {
    List<String> list = new ArrayList<>();
    list.add("jack");
    list.add("tom");
    list.add("mary");
    list.add("tim");
    list.add("tony");
    list.add("eric");
    list.add("jack");
    Iterator<String> iterator = list.iterator();
    while (iterator.hasNext()) {
      String str = iterator.next();
      System.out.println(str);
    }
  }

迭代器和for循環(huán)對(duì)比

  • for循環(huán)適合順序訪問(wèn),或者通過(guò)下標(biāo)進(jìn)行訪問(wèn)
  • 迭代器適合鏈?zhǔn)浇Y(jié)構(gòu)
  • 最終要看使用場(chǎng)景,性能會(huì)有輕微差別,但是可以忽略

注意事項(xiàng)

迭代出的對(duì)象是引用的拷貝,如果修改迭代中的元素,那么就是修改容器對(duì)象的本身??!

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論