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