摘要:通過進行遍歷刪除符合條件的多個元素使用的方式也可以順利刪除和遍歷這里要使用的方法移除當前對象,如果使用的方法,則同樣會出現(xiàn)
1.通過增強的for循環(huán)刪除符合條件的多個元素
/** * 使用增強的for循環(huán) * 在循環(huán)過程中從List中刪除元素以后,繼續(xù)循環(huán)List時會報ConcurrentModificationException */ public void listRemove() { List2.通過增強的for循環(huán)刪除符合條件的一個元素students = this.getStudents(); for (Student stu : students) { if (stu.getId() == 2) students.remove(stu); } }
/** ???* 像這種使用增強的for循環(huán)對List進行遍歷刪除,但刪除之后馬上就跳出的也不會出現(xiàn)異常 ???*/ ??public void listRemoveBreak() { ????List3.通過普通的for刪除刪除符合條件的多個元素students = this.getStudents(); ????for (Student stu : students) { ??????if (stu.getId() == 2) { ????????students.remove(stu); ????????break; ??????} ????} ??} ??
/** * 這種遍歷有可能會遺漏某個元素,因為刪除元素后List的size在 * 變化,元素的索引也在變化,比如你循環(huán)到第2個元素的時候你把它刪了, * 接下來你去訪問第3個元素,實際上訪問到的是原先的第4個元素。當訪問的元素 * 索引超過了當前的List的size后還會出現(xiàn)數(shù)組越界的異常,當然這里不會出現(xiàn)這種異常, * 因為這里每遍歷一次都重新拿了一次當前List的size。 */ public void listRemove2() { Liststudents = this.getStudents(); for (int i=0; i 4.通過Iterator進行遍歷刪除符合條件的多個元素
/** * 使用Iterator的方式也可以順利刪除和遍歷 */ public void iteratorRemove() { Liststudents = this.getStudents(); System.out.println(students); Iterator stuIter = students.iterator(); while (stuIter.hasNext()) { Student student = stuIter.next(); if (student.getId() % 2 == 0) //這里要使用Iterator的remove方法移除當前對象,如果使用List的remove方法,則同樣會出現(xiàn)ConcurrentModificationException stuIter.remove(); } System.out.println(students); }
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/68289.html
摘要:刪除元素后,立即跳出,則正常退出,但不能向后繼續(xù)循環(huán)了刪除后立馬終端循環(huán),會正常跳出,但代價是不能繼續(xù)向后循環(huán)了使用迭代器使用迭代器可,正確無誤的刪除,代碼簡潔優(yōu)雅,推薦使用使用迭代器可,正確無誤的刪除注意這里時而不是 在工作中的許多場景下,我們都會使用到List這個數(shù)據(jù)結(jié)構(gòu),那么同樣的有很多場景下需要刪除List中的某一個元素或某幾個元素,那么我們該如何正確無誤地刪除List中的元素...
摘要:與稀疏數(shù)組對立的為密集數(shù)組,密集數(shù)組的索引會被持續(xù)的創(chuàng)建,并且其元素的數(shù)量等于其長度。創(chuàng)建一個長度為的數(shù)組,并初始化了個元素使用構(gòu)造函數(shù)創(chuàng)建數(shù)組對象的時候,關(guān)鍵字是可以省略的。另外使用和刪除元素是影響數(shù)組的長度的。 說明:本文只總結(jié)了JavaScript數(shù)組在web端的行為,不包括NodeJs端的行為。本文不涉及類型化數(shù)組(TypedArray)的討論、總結(jié)。 一、什么是數(shù)組 數(shù)組的定...
摘要:原因是用發(fā)起任何形式的遍歷時,它的遍歷順序都是從最初就確定的,而在遍歷中刪除了元素會導(dǎo)致當前索引的變化,這樣一是會導(dǎo)致漏刪元素,二是會導(dǎo)致遍歷超過鏈表的長度。所以遍歷一個時要刪除其中的部分元素就需要其他的解決方案。 Python的for可以遍歷一個List,但是在遍歷的過程中刪除元素常常會得到意想不到的結(jié)果甚至程序出現(xiàn)異常,例如: lst = [1, 1, 0, 2, 0, 0, 8,...
摘要:允許從任一方向來遍歷對象,并在遍歷迭代過程中進行修改該對象,還能獲得迭代器的當前位置。這個構(gòu)造函數(shù)是將返回了一個對象給,這也是的存儲實現(xiàn)原理。 一、容器產(chǎn)生的原因 1.數(shù)組的缺點:大小一旦給定就無法更改,除非復(fù)制到一個新的數(shù)組中,開銷大;而容器類都可以自動地調(diào)整自己的尺寸。 2.容器功能的多樣性:容器可以實現(xiàn)各種不同要求,如按不同依據(jù)將元素進行排序或者保證容器內(nèi)無重復(fù)元素等等。關(guān)...
閱讀 1854·2023-04-25 14:49
閱讀 3134·2021-09-30 09:47
閱讀 3131·2021-09-06 15:00
閱讀 2240·2019-08-30 13:16
閱讀 1456·2019-08-30 10:48
閱讀 2688·2019-08-29 15:11
閱讀 1305·2019-08-26 14:06
閱讀 1685·2019-08-26 13:30