반복 중 컬렉션 요소를 제거하는 동안 ConcurrentModificationException 방지
소개
동시에 컬렉션 수정 이를 반복하면 다음과 같은 예상치 못한 동작이 발생할 수 있습니다. ConcurrentModificationException. 이 문제를 방지하려면 다양한 접근 방식을 사용할 수 있습니다.
접근 방법 1: 컬렉션 복사본 반복
한 가지 방법은 컬렉션의 복사본을 만들고 반복하는 것입니다. 원본 컬렉션 대신 해당 사본. 이렇게 하면 원래 컬렉션이 반복 중에 수정되지 않습니다.
예:
List<Foo> fooListCopy = new ArrayList<>(fooList); for (Foo foo : fooListCopy) { // Modify the actual fooList }
접근 방식 2: 컬렉션 반복기 사용
또 다른 접근 방식은 원본 컬렉션에서 제공하는 반복자를 사용하는 것입니다. 반복자는 반복하는 동안 컬렉션을 순회하고 요소를 제거하는 안전한 방법을 제공합니다.
예:
Iterator<Foo> itr = fooList.iterator(); while (itr.hasNext()) { // Modify the actual fooList using itr.remove() }
JDK 8을 사용한 대체 접근 방식 또는 Higher
선택 고려 사항
가장 좋은 접근 방식은 특정 시나리오에 따라 다릅니다.
추가 고려 사항은 다음과 같습니다.
위 내용은 반복 중에 컬렉션에서 요소를 제거할 때 ConcurrentModificationException을 방지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!