问题
I am trying to program an IM software, I want to let user leave the conversation and tell his partner that he has left... I prefer to use for loop instead Iterator, seek all the users and get the user who ask to leave and remove him... like that:
for(Clientuser Cu: EIQserver.OnlineusersList)
if(Cu.ID.equals(thsisUser.ID)) // find the user who ask to leave
{
Omsg.setBody("@@!&$$$$@@@####$$$$"); //code means : clien! ur parter leaves...
sendMessage(Omsg); // sed message to thje partner with that code
EIQserver.OnlineusersList.remove(Cu);// remove the partner
EIQserver.COUNTER--;// decrease counter.
}
I get Exception: java.util.ConcurrentModificationException
I was using iterators, and to get rid of this exception, I convert to for, but the same exception still appears!! how may I get rid of this exception?
回答1:
Use Iterator instead of looping. For example:
Iterator<Clientuser> iterator = EIQserver.OnlineusersList.iterator();
while (iterator.hasNext()) {
Clientuser next = iterator.next();
if(next.ID.equals(thsisUser.ID)) {
Omsg.setBody("@@!&$$$$@@@####$$$$");
sendMessage(Omsg);
iterator.remove();// remove the partner
}
}
回答2:
Faulting line:
EIQserver.OnlineusersList.remove(Cu);
You can only remove elements from a collection that is being iterated over via the Iterator
object you are using to iterate.
for (Iterator<Clientuser> it = EIQserver.OnlineusersList.iterator(); it.hasNext();)
{
Clientuser cu = it.next();
if (!cu.ID.equals(thsisUser.ID))
continue;
// other code
it.remove();
}
回答3:
Use Iterator
for do something with list in loop:
Iterator<Clientuser> iter = EIQserver.OnlineuserList.iterator();
for(;iter.hasNext();) {
Clientuser Cu = iterator.next();
if(Cu.ID.equals(thsisUser.ID)) {
Omsg.setBody("@@!&$$$$@@@####$$$$");
sendMessage(Omsg);
iterator.remove(next);
}
}
回答4:
One possible solution is also to transform the Collection to HashMap, save id's to remove and then remove it from the HashMap.
Collection<Integer> removeIds = new ArrayList<Integer>();
Map<Integer,ClientUser> all = new HashMap<Integer,ClientUser>();
for(Clientuser Cu: EIQserver.OnlineusersList) {
all.put(cu.ID,Cu);
if(Cu.ID.equals(thsisUser.ID)) // find the user who ask to leave
{
Omsg.setBody("@@!&$$$$@@@####$$$$"); //code means : clien! ur parter leaves...
sendMessage(Omsg); // sed message to thje partner with that code
EIQserver.COUNTER--;// decrease counter.
removeIds.add(Cu.ID);
}
}
回答5:
As you are Iterating the EIQserver collection class, you can not remove element from the same class. Use a different collection for Iteration and remove the element from EIQserver class.
List temp = ListofEIQserverobject;
for(Clientuser Cu: temp.OnlineusersList){
..... your code then
EIQserver.OnlineusersList.remove(Cu);
}
来源:https://stackoverflow.com/questions/19702461/java-util-concurrentmodificationexception-in-for-loop