ArrayList调用remove方法需要注意的地方

ArrayList中有remove 方法和 removeAll方法,

ArrayList中不仅继承了接口Collection中的remove方法,而且还扩展了remove方法。

Collection中声明的接口为 public boolean remove(Object o)

public boolean removeAll(Collection<?> c)

ArrayList中含有的方法为public E remove(int index)

实际编程中可能会通过一个Collection来调用remove接口,这种情况下不会报错,但是程序什么也不做。

import java.util.ArrayList;
import java.util.Collection;
import java.util.List;

public class ArrayList01 {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		List<String> allList = null;
		Collection<String> allCollection = null;

		allList = new ArrayList<String>();
		allCollection = new ArrayList<String>();

		allList.add("hello");
		allList.add(0, "world");
		System.out.println(allList);
		allCollection.add("Yes");
		allCollection.add("Good");
		allList.addAll(allCollection);
		allList.addAll(0, allCollection);

		System.out.println(allList);

		allList.remove(allCollection);
                //allList.removeAll(allCollection);
		System.out.println(allList);
	}

}

  

实际编程可以插入任意对象,但是如果想要通过remove(object o)来删除某个对象,这个对象必须是系统自定义的对象,如果不是的话,需要在类中覆写Object类的equals()及hashCode()方法。

时间: 2024-10-14 23:40:02

ArrayList调用remove方法需要注意的地方的相关文章

ArrayList调用remove(int index)抛出UnsupportedOperationException问题分析以及解决记录

使用Arrays转数组成为List后,不能调用add(...)和remove(...)方法,此时如果调用就会抛出UnsupportedOperationException异常 原因 其实Arrays.asList(...)转成的List不是java.util包下面的ArrayList,而是一个内部静态类ArrayList. asList(T... a)方法 public static <T> List<T> asList(T... a) { return new ArrayList

List的remove方法里的坑

今天遇到一件怪事,用一个ArrayList添加了一个对象,再调用ArrayList的remove方法删除该对象,当然这时对象是数据库里查出来的,但内容绝对是一样,却发现remove失败了.演示一下,这里用了自定义的Merchant对象,测试时只需随便自定义一个对象即可: public static void main(String[] args) { List<Merchant> merchants = new ArrayList<>(); Merchant merchant =

ArrayList的Iterator()方法理解

ArrayList有两种迭代器实现,都是按照索引查找,但比正常for循环多了并发操作的安全校验: 1. Itr()的实现,主要功能-后序遍历next()方法 public Iterator<E> iterator() { return new Itr();} public E next() { checkForComodification(); int i = cursor; if (i >= size) throw new NoSuchElementException(); Objec

EntityFramework Core 1.1 Add、Attach、Update、Remove方法如何高效使用详解

EntityFramework Core 1.1方法理论详解 当我们利用EF Core查询数据库时如果我们不显式关闭变更追踪的话,此时实体是被追踪的,关于变更追踪我们下节再叙.就像我们之前在EF 6.x中讨论的那样,不建议手动关闭变更追踪,对于有些特殊情况下,关闭变更追踪可能会导致许多问题的发生. 实体状态 对于EF Core 1.1中依然有四种状态,有的人说不是有五种状态么,UnChanged.Added.Modified.Deleted.Detached.如果我们按照变更追踪来划分的话,实际

List&lt;T&gt;的IndexOf方法和Remove方法

Microsoft地址 List<T>的IndexOf()方法 如果T是值类型的,就按照比较值的方法从列表的第一个元素开始逐个匹配,如果T是引用类型,就比较引用是否相同 举例如下: class A {      public int x;      public A(int x)      {           this.x = x;      } } List<A> listA = new List<A>(); listA.Add( new A(3) ); list

ArrayList中remove()方法删除长度大于5的元素之后下标重定位的问题

1.问题阐述 需求: 有一个ArrayList数组,要求删除长度大于5的字符串,如:arr = {"ab1","123ad","bca","dadfadf","dddaaa","你好啊","我来啦","别跑啊"}: 要求结果输出: {"ab1","123ad","bca","你好

怎么在yar的server端任何地方获得client请求调用的方法

先说下碰到的问题吧:上周调查个问题发现,在rpc server端解析client上传上来的post数据,解包,找函数,执行都在Yar_Server的函数handle中执行了.没有向后面的系统或者服务传递上下文的方法.为了调查问题我们只能在函数调用里面记录哪个方法被调用了. 那么是不是可以在Yar_Server里面试着增加个静态变量保存内容,限于自身能力,现只增加了一个方法,返回了调用的method,用于server端向后面传递. 如下, 小改之后就可以通过 Yar_Server::getCall

Java中LinkedList的remove方法真的耗时O(1)吗?

这个问题其实来源于Leetcode的一道题目,也就是上一篇日志 LRU Cache.在使用LinkedList超时后,换成ArrayList居然AC了,而问题居然是在于List.remove(Object o)这个方法. 我们知道,链表和数组相比,最主要的特点就是add和remove的操作是O(1)的.Java中的链表一般使用LinkedList这个类型,数组一般使用ArrayList.它们同时implements了List这个interface,所以都有remove(int index)和re

Iterator的remove方法可保证从源集合中安全地删除对象(转)

import java.util.ArrayList; import java.util.Iterator; import java.util.List; public class IteratorTest{ public static void main(String[] args) { List<String> list = new ArrayList<String>(); list.add("Test1"); list.add("Test2&qu