从集合List中删除对象,正确写法(异常java.util.ConcurrentModificationException

本文介绍在Java中使用不同方式从List集合中移除null值的方法,并对比了直接遍历删除和使用迭代器删除两种方式,强调了并发修改异常的问题及正确的处理方法。
public class Main {

	public static void main(String[] args) {
		List<Integer> list = new ArrayList<Integer>();
		list.add(null);
		list.add(2);
		list.add(null);
		
		// 错误写法
		for (Integer i : list) {
			if (i == null) {
				list.remove(i);
			}
		}
		
		// 错误写法
		Iterator<Integer> iteratorError = list.iterator();
		while (iteratorError.hasNext()) {
			Integer i = iteratorError.next();
			if (i == null) list.remove(i); //错误写法
		}
		
		// 正确写法一
		Iterator<Integer> iterator = list.iterator();
		while (iterator.hasNext()) {
			Integer i = iterator.next();
			if (i == null) iterator.remove(); //正确写法
		}
		
		// 正确写法二
		if (list != null && list.size() != 0) {
			for (int i = 0; i < list.size(); i++) {
				if (list.get(i) == null) {
					list.remove(i);
				}
			}
		}
	}
}

正确写法一最常用,异常原因分析http://www.cnblogs.com/dolphin0520/p/3933551.html

Hibernate: select paymes0_.ID as ID, paymes0_.TRANSACTION_SERIAL_NO as TRANSACT2_, paymes0_.ITEM_NO as ITEM_NO, paymes0_.ACCOUNT_NO as ACCOUNT_NO, paymes0_.ACCOUNT_NAME as ACCOUNT_5_, paymes0_.BANK_TYPE as BANK_TYPE, paymes0_.OPEN_BANK as OPEN_BANK, paymes0_.BANK_TRANSCACTION_DATE as BANK_TRA8_, paymes0_.CURRENCY as CURRENCY, paymes0_.DETAIL_TYPE as DETAIL_10_, paymes0_.LOAN_TYPE as LOAN_TYPE, paymes0_.INCURRED_AMOUNT as INCURRE12_, paymes0_.PURPOSE as PURPOSE, paymes0_.DIGEST as DIGEST, paymes0_.OPPOSITE_ACCOUNT as OPPOSIT15_, paymes0_.CUSTOMER_NUMBER as CUSTOME16_, paymes0_.OPPOSITE_NAME as OPPOSIT17_, paymes0_.OPPOSITE_OPENING_BANK as OPPOSIT18_, paymes0_.PAYMENT_NATURE_FLAG as PAYMENT19_, paymes0_.PAYMENT_NATURE as PAYMENT20_, paymes0_.DETAIL_SOURCE as DETAIL_21_, paymes0_.ACCOUNT_STATUS as ACCOUNT22_, paymes0_.REMARK as REMARK, paymes0_.ERP_SERIAL_NUMBER as ERP_SER24_, paymes0_.PAY_APPLY_REMARK1 as PAY_APP25_, paymes0_.RESERVE_FIELD1 as RESERVE26_, paymes0_.POSTSCRIPT as POSTSCRIPT, paymes0_.VOUCHER_CODE as VOUCHER28_, paymes0_.BOOKING_DATE as BOOKING29_, paymes0_.PERSONALIZE_FIELD1 as PERSONA30_, paymes0_.CREATE_DATE as CREATE_31_, paymes0_.CREATE_TIME as CREATE_32_, paymes0_.OWER as OWER, paymes0_.ACTUAL_AMOUNT as ACTUAL_34_, paymes0_.DATA_STATUS as DATA_ST35_, paymes0_.DATA_STATUS_MESSAGE as DATA_ST36_, paymes0_.BUKRS as BUKRS, paymes0_.HKONT as HKONT, paymes0_.STATUS as STATUS, paymes0_.SUBMIT_DATE as SUBMIT_40_, paymes0_.SUBMIT_TIME as SUBMIT_41_, paymes0_.VOUCHER_STATUS as VOUCHER42_ from CERP_CRM_PAY_MES paymes0_ where (id=19 ) java.util.ConcurrentModificationException at java.util.ArrayList$Itr.checkForComodification(ArrayList.java:909) at java.util.ArrayList$Itr.next(ArrayList.java:859) 什么错误?
07-15
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值