今天在修改别的代码的时候遇到这的问题,要删除掉集合里的元素
这种写法一运行就会报如下异常:
因为list在循环中的时候是不可以删除它的元素的。后来我是这样做的,一种很笨的方法,思路是这样的:创建一个List专门存放要被删除的元素,循环过后,用List.removeAll方法把元素删除。代码如下:
这样也确实可以解决问题了,但是方法实在太笨重,其实可以有更简单的更高效的方法,就是用Iterator.remove方法,如下:
多实践,多累计,技术方面总会有提升的。
Java代码
- public void operate(List list){
- for (Iterator it = list.iterator(); it.hasNext();) {
- String str = (String)it.next();
- if (str.equals("chengang")){
- list.remove(str);
- }
- }
- }
这种写法一运行就会报如下异常:
Java代码
- Exception in thread "main" java.util.ConcurrentModificationException
- t java.util.AbstractList$Itr.checkForComodification(AbstractList.java:449)
因为list在循环中的时候是不可以删除它的元素的。后来我是这样做的,一种很笨的方法,思路是这样的:创建一个List专门存放要被删除的元素,循环过后,用List.removeAll方法把元素删除。代码如下:
Java代码
- public void operate(List list){
- List removeList= new ArrayList();
- for (Iterator it = list.iterator(); it.hasNext();) {
- String str = (String)it.next();
- if (str.equals("chengang")){
- removeList.add(str);
- }
- }
- list.removeAll(removeList);
- }
这样也确实可以解决问题了,但是方法实在太笨重,其实可以有更简单的更高效的方法,就是用Iterator.remove方法,如下:
Java代码
- for (Iterator it = list.iterator(); it.hasNext();) {
- String str = (String)it.next();
- if (str.equals("chengang")){
- it.remove();
- }
- }
多实践,多累计,技术方面总会有提升的。