linkedlist和array list區(qū)別 java中foreach和迭代器在遍歷List集合,一些情況下為什么能使用集合自動(dòng)的刪除方法刪除元素?
java中foreach和迭代器在遍歷List集合,一些情況下為什么能使用集合自動(dòng)的刪除方法刪除元素?當(dāng)您是<70時(shí),倒數(shù)第二位是66。您沒(méi)有引發(fā)異常,因?yàn)橐郧暗牧斜泶笮∈?。刪除66后,列表大小
java中foreach和迭代器在遍歷List集合,一些情況下為什么能使用集合自動(dòng)的刪除方法刪除元素?
當(dāng)您是<70時(shí),倒數(shù)第二位是66。您沒(méi)有引發(fā)異常,因?yàn)橐郧暗牧斜泶笮∈?。刪除66后,列表大小為4。第一次遍歷列表大小為5的數(shù)組時(shí),指針66位于index=4中。遍歷列表大小為4的數(shù)組時(shí),指針66位于index=4中newlist.size文件()。
ArrayList中的此方法將判斷列表已被讀取,因此不會(huì)引發(fā)異常。
1]]2
3
公共布爾hasnext(){
返回光標(biāo)!=size
}
A< 90,第二位變了,列表的大小也變了
看ArrayList的源代碼,調(diào)用這個(gè)方法檢查列表的大小是否每次都變,但是這個(gè)方法發(fā)生在hasnext方法之后
1
2
3
4
final void Checkforcomodification(){
if(modcount!=expectedmodcount)
如何將數(shù)組中的元素放入list集合中?
在Java中獲取列表中一維數(shù)組中的元素需要兩個(gè)步驟。步驟1:獲取列表的迭代器并從迭代器遍歷數(shù)組。第2部分:遍歷數(shù)組并檢索存儲(chǔ)在數(shù)組中的元素。Java的list集合只能存儲(chǔ)引用類(lèi)型變量,不能存儲(chǔ)基本類(lèi)型變量。因此,當(dāng)列表存儲(chǔ)數(shù)組時(shí),它將數(shù)組本身存儲(chǔ)到集合中,而不是存儲(chǔ)數(shù)組中的元素。
使用Iterator遍歷集合時(shí),首先需要調(diào)用什么方法?
遍歷集合時(shí),首先通過(guò)調(diào)用集合的iterator()方法獲取iterator對(duì)象,然后使用hashnext()方法確定集合中是否有下一個(gè)元素。如果有,則調(diào)用next()方法取出元素。否則,意味著已到達(dá)集合的結(jié)尾,并停止遍歷元素。
使用迭代器遍歷集合時(shí),刪除元素為何不能用集合定義的remove()方法?
在STL中,remove()只是將要?jiǎng)h除的元素后面的元素移動(dòng)到向量的前端,而不是將其刪除。
要實(shí)際刪除它,請(qǐng)使用erase()。
刪除list集合為什么要用迭代器?
刪除其中一個(gè)時(shí),對(duì)應(yīng)數(shù)組中的元素會(huì)清空刪除位置的下標(biāo),然后將后續(xù)數(shù)據(jù)逐個(gè)向前推,導(dǎo)致最后一個(gè)位置的下標(biāo)為空。當(dāng)您到達(dá)最后一個(gè)位置時(shí),如果沒(méi)有數(shù)據(jù),數(shù)組將被報(bào)告為越界。迭代器的原理是只能取下一項(xiàng)。沒(méi)有下標(biāo),這將確保數(shù)據(jù)的一致性
生成器不僅“記住”其數(shù)據(jù)狀態(tài),而且還記住程序的執(zhí)行位置。
(2)Iterator
生成器必須是Iterator,并且必須是Iterator object
(3)區(qū)別:①生成器是生成元素的,Iterator是訪問(wèn)集合元素的一種方式;②Iterator輸出生成器內(nèi)容;③Iterator是支持next()操作的對(duì)象;④Iterator:其中Iterator object表示數(shù)據(jù)流,它可以是一個(gè)有序序列,我們不能預(yù)先知道序列的長(zhǎng)度。我們只能通過(guò)nex()函數(shù)計(jì)算下一個(gè)數(shù)據(jù)。它可以看作生成器的一個(gè)子集。