遍历Set集合remove掉不需要的数据,List不能在遍历的时候remove

博客内容提到在遍历List时不能直接remove,需使用iterator.remove避免并发修改异常。对于Set,遍历中进行remove操作需确保集合不被修改,否则可能因hashCode变化导致移除失败。建议在需要删除时复制一个新的Set进行操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

for(Iterator<IAddress> it=addSet.iterator();it.hasNext();){
	IAddress address = it.next();
	if(address.getId() != null){
		Boolean flag = false;
		for(IAddress addr : set){
			if(addr.getId().equals(address.getId())){
				flag = true;
				break;
			}
		}
		if(!flag){
			it.remove();
		}
	}
}

 List遍历的时候不能直接 remove,实现办法是用 iterator.remove,否则会报ConcurrentModificationException 

 

 

注意set 在remove操作时set集合不能再有任何修改,否则hashcode发生改变,则不能remove成功

例如以下case

Hibernate.initialize(subAccount.getAuthorizors());


			if(subAccount.getAuthorizors() != null){
				
				Iterator<IAuthorizor> iterator = subAccount.getAuthorizors().iterator();
				
				while(iterator.hasNext()){
					
					IAuthorizor authorizor = iterator.next();
					
					if(authorizor != null){
					
						Hibernate.initialize(authorizor.getAuthorizorIDs());
						
						Hibernate.initialize(authorizor.getAuthorizorAddresses());

						Hibernate.initialize(authorizor.getAuthorizorPhones());

						Hibernate.initialize(authorizor.getNationality());
						
					}
					
				}
				
			}

authorizor 重新initialize之后,remove 不会成功,所以,可以将db取到的set copy 给一个新的set。再remove

Set<IAuthorizor> tempAuthSet = subAccount.getAuthorizors();//db data
Set<IAuthorizor> dbAuthSet = (Set<IAuthorizor>)ObjectUtil.deepCopy(tempAuthSet);
			//Delete authorizor
			for(Iterator<IAuthorizor> it = dbAuthSet.iterator();it.hasNext();){
				IAuthorizor dbAuthorizor = it.next();
			   if(dbAuthorizor.getId() != null){
					Boolean flag = false;
					for(IAuthorizor authorizor : authSet){
						if(authorizor.getId() != null){
							if(authorizor.getId().equals(dbAuthorizor.getId())){
								flag = true;
								break;
							}
						}
					}
					if(!flag){
						//it.remove();
						dbAuthSet.remove(dbAuthorizor);
					}
				}
			}
			
			dbAuthSet.addAll(addAuthSet);
			subAccount.setAuthorizors(dbAuthSet);

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值