4

该方法何时以及为什么boolean java.util.List.remove(Object object)返回 false?

该文件指出

[方法返回] 如果此 List 被此操作修改,则返回 true,否则返回 false。

为什么操作不会在 List 上生效?

(注意:我正在使用的 List 的实现是ArrayList

更新: 我试图删除的对象确实存在于列表中。我将类添加到List(因此是参数this)并将this(在同一个类中)传递给 remove 方法。因此该对象应该存在于列表中(或不存在?)。

更新: 这是代码。看看delay()方法。在那里我尝试从List.

public class Timer extends Object {

    private static List<Timer> allTimers;
    private Long startTime;
    private int delayTime;
    private boolean registered;

    String name;

    public Timer(String name) {
        this.name = name;
        this.registered = true;
        allTimers.add(this);
        Log.d("SpaceDroid", "Foo: Created timer: " + name + " Size: " + this.allTimers.size());

    }

    public Timer(String name, int delayTime) {
        this(name);
        this.delayTime = delayTime;

    }

    public void setDelayTime(int delayTime) {
        this.delayTime = delayTime;

    }

    public boolean delay() {
        if(this.startTime == null) {
            this.startTime = System.currentTimeMillis();
        }

        if(startTime + this.delayTime < System.currentTimeMillis()) {
            if(this.registered) {
                Log.d("SpaceDroid", "Foo: Trying to remove timer: " + name);
                if(this.allTimers.remove(this)) {
                    Log.d("SpaceDroid", "Foo: Successfully removed timer: " + name);
                }
                else {
                    Log.d("SpaceDroid", "Foo: Did not remove timer: " + name);
                }

            }
            return true;

        }
        else {
            return false;

        }

    }

    // The same as resume, just renew the startTime

    public void reset() {
        this.startTime = null;
        this.registered = true;
        this.allTimers.add(this);

    }

    public void resume() {
        this.startTime = System.currentTimeMillis();

    }

    public void pause() {
        // Check if timer is still running
        if(!this.delay()) {
            // Calculate new delayTime
            delayTime = (int) ((startTime + this.delayTime) - System.currentTimeMillis());
            Log.d("SpaceDroid", "Foo: New delay time: " + delayTime + " for timer: " + name);

        }


    }

    public static void resumeAllTimers() {
        List<Timer> timers = new ArrayList<Timer>(Timer.allTimers);
        for (Timer timer : timers) {
            timer.resume();
        }

    }

    public static void pauseAllTimers() {
        List<Timer> timers = new ArrayList<Timer>(Timer.allTimers);
        for (Timer timer : timers) {
            timer.pause();
        }

    }

    public static void disposeAllTimers() {
        Timer.allTimers.clear();
        Timer.allTimers = null;

    }

    public static void initializeAllTimers() {
        allTimers = new ArrayList<Timer>();

    }


}
4

3 回答 3

10

如果Object传入的实际上不在列表中,它不会对列表产生任何影响,因此返回 false。

编辑(感谢 Jai):该方法使用特定Object的 sequals()方法来确定它是否包含该对象。因此,如果您有自定义对象,请确保您覆盖该equals()方法,以及hashCode()(以维护方法之间的一般合​​同)。

于 2013-04-20T12:33:06.357 回答
2

由于 List 是一个接口,因此它不会有一个具体的实现作为示例。但是从 ArrayList 中获取,如果出现以下情况,它将返回false

  • 您传递 null 并且列表中没有 null 对象,或者
  • 你传递了一个未在列表中找到的对象

来自 ArrayList.java

     public boolean remove(Object o) {
         if (o == null) {
             for (int index = 0; index < size; index++)
                 if (elementData[index] == null) {
                     fastRemove(index);
                     return true;
                 }
         } else {
             for (int index = 0; index < size; index++)
                 if (o.equals(elementData[index])) {
                     fastRemove(index);
                     return true;
                 }
         }
         return false;
     }

为了完整起见,添加 fastRemove 的代码:

 private void fastRemove(int index) {
      modCount++;
      int numMoved = size - index - 1;
      if (numMoved > 0)
          System.arraycopy(elementData, index+1, elementData, index,
                           numMoved);
      elementData[--size] = null; // Let gc do its work
  }

证明:

public static void main(String[] args) {
        ArrayList l = new ArrayList();
        System.out.println("Removing null on empty list: " + l.remove(null));
        System.out.println("Removing an object that won't be found: " + l.remove(new Object()));
}

结果:

Removing null on empty list: false
Removing an object that won't be found: false
于 2013-04-20T12:44:27.577 回答
1

从这个文档

如果指定元素存在,则从该列表中删除第一次出现的指定元素(可选操作)。如果此列表不包含该元素,则它不变。更正式地说,删除具有最低索引 i 的元素,使得 (o==null ? get(i)==null : o.equals(get(i))) (如果存在这样的元素)。如果此列表包含指定的元素(或等效地,如果此列表因调用而更改),则返回 true。

于 2013-04-20T12:33:58.447 回答