java - 对象的并发修改异常

标签 java concurrentmodification

我遇到并发修改异常问题。我已更改代码以使用迭代器,但是当我删除对象时仍然遇到这些问题。我的错误发生在线上

theEnemy = (Enemy) EnemyItr.next();

我不确定如何解决这个问题,因为它是代码中非常重要的一部分。

for (Iterator EnemyItr = activeEnemies.iterator(); EnemyItr.hasNext(); ){

    theEnemy = (Enemy) EnemyItr.next(); 
    try {

        try {

            if (theEnemy.x < 0 && theEnemy.y >= 5) {
                activeEnemies.remove(theEnemy);
            }
        } catch (Exception e) {
            System.err.println("Cannot Remove Enemy");
        }

        Enemy.pathFind(Enemy.getXBlockOfEnemy(theEnemy.x), Enemy.getXBlockOfEnemy(theEnemy.y), theEnemy.x, theEnemy.y);

        if (Enemy.right) {
            theEnemy.x += Enemy.speed;
            //System.out.println("right");
            //System.out.println(theEnemy.x + " " + theEnemy.y);
        } else if (Enemy.down) {
            theEnemy.y += Enemy.speed;
            //System.out.println("down");
            //System.out.println(theEnemy.x + " " + theEnemy.y);;
        } else if (Enemy.up) {
            theEnemy.y -= Enemy.speed;
            //System.out.println("up");
            //System.out.println(theEnemy.x + " " + theEnemy.y);
        } else if (Enemy.left) {
            theEnemy.x -= Enemy.speed;
            //System.out.println("left");
            //System.out.println(theEnemy.x + " " + theEnemy.y);
        } else {
            System.out.println("Enemy Lost.");
            //System.out.println(theEnemy.x + " " + theEnemy.y);
        }

        g.drawImage(enemy, theEnemy.x, theEnemy.y, this);
        //System.out.println(Enemy.getXBlockOfEnemy(theEnemy.x));

        //drawing health bar
        if (Input.displayUI) {
            g.setColor(Color.LIGHT_GRAY);
            g.fillRect(theEnemy.x, theEnemy.y - 10, 70, 10);
            g.setColor(Color.RED);
            g.fillRect(theEnemy.x + 2, theEnemy.y - 10 + 1, 68, 8);
            g.setColor(Color.GREEN);
            g.fillRect(theEnemy.x + 2, theEnemy.y - 10 + 1, (int) (.68 * theEnemy.enemylife), 8);
        }

    } catch (ConcurrentModificationException e) {
        theEnemy = null;
    }

}

最佳答案

在迭代集合时从集合中删除元素的唯一机会是使用迭代器本身的remove() 方法。但由于这是一个可选方法,如果您的迭代器不支持删除方法,您可能必须使用此处其他答案的建议。

简而言之:使用迭代器的remove方法而不是集合本身的remove方法。

关于java - 对象的并发修改异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16595218/

相关文章:

java - 为什么会引发ConcurrentModificationException以及如何对其进行调试

java - 为什么jDateChooser的值又回到默认值了?

java - Java 中的 Android .NET Trim 函数?

java - 用于基于天的缓存过期的缓存或 MultiMap?

java - 并发修改异常

java - LinkedHashMap ConcurrentModificationException 错误

java - 一起使用java和C++的Android项目

java - LIBGDX 不渲染由类创建的 Sprite

java.util.ConcurrentModificationException -- 执行 IO 操作时的错误(不是列表)

使用正确的remove()方法时显示java.util.ConcurrentModificationException