ConcurrentModificationException

ConcurrentModificationException

我有一个正常的数据库调用,该调用从数据库中收集信息。我使用这些信息来创建我的对象(CallQueue),然后将这些对象添加到列表中,然后返回列表。

突然间,我发现我的原始代码无法按预期工作,因为我创建了重复项,因此现在我试图使所有重复项都无法创建!但有个问题!

我无法遍历列表并检查是否已创建对象!

这是我的代码:

while (query.next()) {
    if (!queues.isEmpty()) {
        /*This gives the Execption->*/
        for (CallQueue callQueue : queues) {
            if (callQueue.getType().equals(query.getString("KØ"))) {
                double decimalTime = query.getDouble("TID");
                int hourOfDay = (int)Math.round(24 * decimalTime);
                int callAmount = query.getInteger("ANTAL_KALD");
                if (hourOfDay > 19) {
                    hourOfDay = 19;
                }
                callQueue.addCallsByTime(hourOfDay, callAmount);
            } else {
                String queueName = query.getString("Kø");
                if (!queueName.equalsIgnoreCase("PrivatOverflow")) {
                    CallQueue cq = new CallQueue(query.getString("KØ"));
                    double decimalTime = query.getDouble("TID");
                    int hourOfDay = (int)Math.round(24 * decimalTime);
                    int callAmount = query.getInteger("ANTAL_KALD");
                    if (hourOfDay > 19) {
                        hourOfDay = 19;
                    }
                    cq.addCallsByTime(hourOfDay, callAmount);
                    queues.add(cq);
                }
            }
        }
    } else {
        String queueName = query.getString("Kø");
        if (!queueName.equalsIgnoreCase("PrivatOverflow")) {
            CallQueue cq = new CallQueue(query.getString("KØ"));
            double decimalTime = query.getDouble("TID");
            int hourOfDay = (int)Math.round(24 * decimalTime);
            int callAmount = query.getInteger("ANTAL_KALD");
            if (hourOfDay > 19) {
                hourOfDay = 19;
            }
            cq.addCallsByTime(hourOfDay, callAmount);
            queues.add(cq);
        }
    }
}

for (CallQueue callQueue : queues) {
    System.out.println(callQueue.getType());
}
query.Close();
return queues;


我从中得到的执行是:

Caused by: java.util.ConcurrentModificationException


香港专业教育学院试图在ConcurrentModificationException查找执行

谁能帮我解决这个问题?

最佳答案

您正在迭代中进行添加。根据规范,不允许您修改要迭代的集合。

经典的解决方案是首先创建集合的副本,然后对其进行迭代。另一种解决方案是不使用迭代器(简短的foreach表示法是隐式使用它),而是使用索引手动进行迭代。

for (int i=0; i<queues.size(); i++) {
    CallQueue callQueue = queues.get(i);

    ... code goes here

}


更好的解决方案是使用Set而不是列表(除非顺序对您很重要)。那确实意味着您将必须正确实现equals和hashcode。

顺便说一句:我相信您的代码有缺陷。您正在遍历列表,如果遇到的项目不匹配,则在末尾添加一个。这意味着,如果您要查找的项目是列表中的第x个项目,则您将添加x次新项目。我严重怀疑那是您所需要的。如果您进行一些重构,这将立即变得清晰。

关于java - ConcurrentModificationException,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/13609323/

10-11 03:51