java獲取數(shù)組元素下標(biāo) 在java中集合中迭代是怎么一回事兒?為什么要進(jìn)行集合的迭代?
在java中集合中迭代是怎么一回事兒?為什么要進(jìn)行集合的迭代?事實(shí)上,嚴(yán)格地說(shuō),迭代是一種設(shè)計(jì)模式。迭代的目的是遍歷某一類(lèi)型數(shù)據(jù)集的內(nèi)容,而不知道該類(lèi)型數(shù)據(jù)的數(shù)據(jù)結(jié)構(gòu)。實(shí)現(xiàn)思想是定義一個(gè)迭代器接口,它
在java中集合中迭代是怎么一回事兒?為什么要進(jìn)行集合的迭代?
事實(shí)上,嚴(yán)格地說(shuō),迭代是一種設(shè)計(jì)模式。迭代的目的是遍歷某一類(lèi)型數(shù)據(jù)集的內(nèi)容,而不知道該類(lèi)型數(shù)據(jù)的數(shù)據(jù)結(jié)構(gòu)。
實(shí)現(xiàn)思想是定義一個(gè)迭代器接口,它至少聲明兩個(gè)方法:hasnext()和next()。通過(guò)hasnext()判斷是否有遍歷元素,并通過(guò)next()返回遍歷元素。對(duì)于具體的實(shí)現(xiàn),我們可以根據(jù)不同的需求創(chuàng)建不同的實(shí)現(xiàn)類(lèi)。
換句話(huà)說(shuō),迭代沒(méi)有編程語(yǔ)言屬性,但幾乎所有編程語(yǔ)言都支持迭代。
在Java中,無(wú)需迭代即可遍歷集合。當(dāng)然,無(wú)需迭代的遍歷僅限于list接口的實(shí)現(xiàn)類(lèi)。因?yàn)榱斜斫涌谥付丝梢酝ㄟ^(guò)集合索引獲得相應(yīng)的值,所以無(wú)論列表是通過(guò)數(shù)組實(shí)現(xiàn)還是通過(guò)鏈表實(shí)現(xiàn)。
但是,Java中的集合不僅是列表,而且是集合。這種非列表集合不能通過(guò)索引獲得指定的元素,因此使用迭代方法。
除了list和set之外,Java還有一個(gè)雙列集合,也稱(chēng)為鍵值對(duì)集合。但是,這種集合遍歷不能直接迭代。相反,我們使用折衷方法,要么先獲取鍵值集,要么通過(guò)遍歷鍵值遍歷映射,要么獲取鍵值集地圖輸入橫穿。
總之,迭代法不屬于任何編程語(yǔ)言,它只是一種設(shè)計(jì)思想,但大多數(shù)編程語(yǔ)言都會(huì)實(shí)現(xiàn)它,包括Java。