迭代器為什么不定義成一個(gè)類(lèi),而是一個(gè)接口?
假設(shè)迭代器定義的是一個(gè)類(lèi),這樣我們就可以創(chuàng)建該類(lèi)的對(duì)象,調(diào)用該類(lèi)的方法來(lái)實(shí)現(xiàn)集合的遍歷。但是,java中提供了很多集合類(lèi),而這些集合類(lèi)的數(shù)據(jù)結(jié)構(gòu)是不同的,所以,存儲(chǔ)的方式和遍歷的方式應(yīng)該是不用的,進(jìn)而他們的遍歷方式也應(yīng)該不是一樣的,最終,就沒(méi)有定義迭代器類(lèi)的。
而無(wú)論你是那種集合,你都應(yīng)該具備獲取元素的操作,并且最好在輔助于判斷功能,這樣在獲取前,先判斷,這樣就更不容易出錯(cuò),也就是說(shuō),判斷功能和獲取功能應(yīng)該是一個(gè)集合遍歷所具備的,而每種集合的方式又不太一樣,所以我們就把這兩個(gè)功能提取出來(lái),并不提供具體實(shí)現(xiàn),這種方式就是接口。
那么,真正的具體的實(shí)現(xiàn)類(lèi)在哪里呢?
在真正的具體的子類(lèi)中,以?xún)?nèi)部類(lè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() {}
}
}
本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶(hù)發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)
點(diǎn)擊舉報(bào)。