Why am I not getting a java.util.ConcurrentModificationException in this example?

后端 未结 10 2119
佛祖请我去吃肉
佛祖请我去吃肉 2020-11-22 07:59

Note: I am aware of the Iterator#remove() method.

In the following code sample, I don\'t understand why the List.remove in main

相关标签:
10条回答
  • 2020-11-22 08:46

    Check your code man....

    In the main method you are trying to remove the 4th element which is not there and hence the error. In the remove() method you are trying to remove the 3rd element which is there and hence no error.

    0 讨论(0)
  • 2020-11-22 08:47

    Change Iterator for each into for loop to solve.

    And the Reason is:

    The iterators returned by this class's iterator and listIterator methods are fail-fast: if the list is structurally modified at any time after the iterator is created, in any way except through the iterator's own remove or add methods, the iterator will throw a ConcurrentModificationException.

    --Referred Java Docs.

    0 讨论(0)
  • 2020-11-22 08:50

    I had that same problem but in case that I was adding en element into iterated list. I made it this way

    public static void remove(Integer remove) {
        for(int i=0; i<integerList.size(); i++) {
            //here is maybe fine to deal with integerList.get(i)==null
            if(integerList.get(i).equals(remove)) {                
                integerList.remove(i);
            }
        }
    }
    

    Now everything goes fine because you don't create any iterator over your list, you iterate over it "manually". And condition i < integerList.size() will never fool you because when you remove/add something into List size of the List decrement/increment..

    Hope it helps, for me that was solution.

    0 讨论(0)
  • 2020-11-22 08:51

    The forward/iterator method does not work when removing items. You can remove the element without error, but you will get a runtime error when you try to access removed items. You can't use the iterator because as pushy shows it will cause a ConcurrentModificationException, so use a regular for loop instead, but step backwards through it.

    List<Integer> integerList;
    integerList = new ArrayList<Integer>();
    integerList.add(1);
    integerList.add(2);
    integerList.add(3);
    
    int size= integerList.size();
    
    //Item to remove
    Integer remove = Integer.valueOf(3);
    

    A solution:

    Traverse the array in reverse order if you are going to remove a list element. Simply by going backwards through the list you avoid visiting an item that has been removed, which removes the exception.

    //To remove items from the list, start from the end and go backwards through the arrayList
    //This way if we remove one from the beginning as we go through, then we will avoid getting a runtime error
    //for java.lang.IndexOutOfBoundsException or java.util.ConcurrentModificationException as when we used the iterator
    for (int i=size-1; i> -1; i--) {
        if (integerList.get(i).equals(remove) ) {
            integerList.remove(i);
        }
    }
    
    0 讨论(0)
提交回复
热议问题