日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

迭代器的原理及源碼解析

 櫻花夢(mèng)_張藝馨 2016-11-23
迭代器為什么不定義成一個(gè)類,而是一個(gè)接口?
    假設(shè)迭代器定義的是一個(gè)類,這樣我們就可以創(chuàng)建該類的對(duì)象,調(diào)用該類的方法來(lái)實(shí)現(xiàn)集合的遍歷。但是,java中提供了很多集合類,而這些集合類的數(shù)據(jù)結(jié)構(gòu)是不同的,所以,存儲(chǔ)的方式和遍歷的方式應(yīng)該是不用的,進(jìn)而他們的遍歷方式也應(yīng)該不是一樣的,最終,就沒(méi)有定義迭代器類的。
而無(wú)論你是那種集合,你都應(yīng)該具備獲取元素的操作,并且最好在輔助于判斷功能,這樣在獲取前,先判斷,這樣就更不容易出錯(cuò),也就是說(shuō),判斷功能和獲取功能應(yīng)該是一個(gè)集合遍歷所具備的,而每種集合的方式又不太一樣,所以我們就把這兩個(gè)功能提取出來(lái),并不提供具體實(shí)現(xiàn),這種方式就是接口。
那么,真正的具體的實(shí)現(xiàn)類在哪里呢?
 在真正的具體的子類中,以內(nèi)部類的方式體現(xiàn)的。
====================代碼實(shí)現(xiàn)==================
public interface Iterator{
 public abstract boolean hasNext();
 public abstract next();
}
public interface Iterable{
 Iterator iterator();
}
public interface Collection extends Iterable{
 Iterator iterator();
}
public interface List extends Collection {
 Iterator iterator();
}
public class ArrayList implements List{
 public Iterator iterator() {
        return new Itr();
    }
    private class Itr implements Iterator {
      public boolean hasNext() {}
       public Object next() {}
    }
}

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多