Java集合Collection接口中的常用方法演示

本文详细介绍了Java中Collection接口的各种常用方法,包括添加、查询、删除集合元素,以及集合间的并集、交集、差集运算等核心操作。通过具体实例展示了如何使用这些方法。

由于接口不可以创建对象,所以,以下方法的演示将以Collection接口的子接口List的实现类ArrayList()进行演示。

添加 add(Objec tobj) 和 addAll(Collection coll)

(1)add(Objec tobj)添加一个对象,如果是基本数据类型,则自动装箱。

		ArrayList list1 = new ArrayList();
        Date date = new Date();
        
        list1.add(1);//基本数据类型自动装箱
        list1.add(date);//引用数据类型

        System.out.println(list1);

输出结果
在这里插入图片描述

(2)addAll(Collection coll)添加一个集合。

		ArrayList list1 = new ArrayList();
        list1.add("张三");
        list1.add(123);

        ArrayList list2 = new ArrayList();
        list2.add("李四");
        list2.add(55);
        
        list1.addAll(list2);//将集合list2加到集合list1中
        System.out.println(list1);

输出结果
在这里插入图片描述

获取有效元素的个数 int size()

int size()

		ArrayList list1 = new ArrayList();
        Date date = new Date();

        list1.add(1);
        list1.add(date);

        System.out.println(list1.size());

输出结果
在这里插入图片描述

清空集合 void clear()

void clear()

        ArrayList list1 = new ArrayList();
        Date date = new Date();

        list1.add(1);
        list1.add(date);

        list1.clear();//清空集合

        System.out.println(list1.size());//输出元素个数

输出结果
在这里插入图片描述

是否是空集合 boolean isEmpty()

boolean isEmpty()

        ArrayList list1 = new ArrayList();
        Date date = new Date();

        System.out.println(list1.isEmpty());//未添加元素,判断是否是空集合

        list1.add(1);
        list1.add(date);

        System.out.println(list1.isEmpty());//添加完元素,判断是否是空集合

输出结果
在这里插入图片描述

是否包含某个元素 boolean contains(Object obj) 和 boolean containsAll(Collection c)

(1)boolean contains(Object obj):是通过元素的equals方法来判断是否是同一个对象。

		ArrayList list1 = new ArrayList();
        Date date = new Date();
        
        list1.add(1);
        list1.add(date);

        System.out.println(list1.contains(1));

输出结果
在这里插入图片描述

(2)boolean containsAll(Collection c):也是调用元素的equals方法来比较的。拿两个集合的元素挨个比较。

        ArrayList list1 = new ArrayList();
        ArrayList list2 = new ArrayList();

        //list1赋值
        list1.add(1);
        list1.add("张三");

        //list2赋值
        list2.add(1);
        list2.add("张三");

        System.out.println(list1.containsAll(list2));

输出结果
在这里插入图片描述
注意:如果是自定义对象,则需要在对象中重写Object的equals方法,否则比较的是地址。重写后比较的是属性的值。

删除 boolean remove(Object obj) 和 boolean removeAll(Collection coll)

(1)boolean remove(Object obj) :通过元素的equals方法判断是否是要删除的那个元素。只会删除找到的第一个元素。

        ArrayList list1 = new ArrayList();

        list1.add("张三");
        list1.add("李四");
        list1.add("张三");
        list1.add("张三");
        list1.add("张三");

        list1.remove("张三");//在集合list1中删除元素"张三"

        System.out.println(list1);

输出结果
在这里插入图片描述

(2)boolean removeAll(Collection coll):取当前集合的差集。(即A-B=A-AB)

        ArrayList list1 = new ArrayList();
        ArrayList list2 = new ArrayList();

        list1.add("张三");
        list1.add("李四");

        list2.add("王五");
        list2.add("李四");


        list1.removeAll(list2);

        System.out.println(list1);

输出结果
在这里插入图片描述

取两个集合的交集 boolean retainAll(Collection c)

boolean retainAll(Collection c):把交集的结果存在当前集合中,不影响c。

        ArrayList list1 = new ArrayList();
        ArrayList list2 = new ArrayList();

        list1.add("张三");
        list1.add("李四");

        list2.add("王五");
        list2.add("李四");
        
        list1.retainAll(list2);

        System.out.println(list1);

输出结果
在这里插入图片描述

集合是否相等 boolean equals(Object obj)

boolean equals(Object obj)

        ArrayList list1 = new ArrayList();
        ArrayList list2 = new ArrayList();

        list1.add("张三");
        list1.add("李四");

        list2.add("张三");
        list2.add("李四");
        
        System.out.println(list1.equals(list2));

输出结果
在这里插入图片描述
注意:该原理是调用集合元素的equals方法进行比较,如果集合元素是自定义对象,则必须要重写equals方法,否则比较的是地址值。

转成对象数组 Object[] toArray()

Object[] toArray()

		ArrayList list1 = new ArrayList();

        list1.add("张三");
        list1.add("李四");

        Object[] objects = list1.toArray();

获取集合对象的哈希值

hashCode()

        ArrayList list1 = new ArrayList();

        list1.add("张三");
        list1.add("李四");

        System.out.println(list1.hashCode());

输出结果
在这里插入图片描述

遍历 iterator()

iterator()

        ArrayList list1 = new ArrayList();

        list1.add("张三");
        list1.add("李四");

        Iterator iterator = list1.iterator();

        while (iterator.hasNext()){
            String next = (String) iterator.next();

            System.out.println(next);
        }

输出结果
在这里插入图片描述

### Java 中向 `Collection` 接口集合添加元素 在 Java 中,`Collection` 是一个核心接口,定义了许多操作集合的标准方法。其中,`add(E e)` 方法用于将指定的元素添加到集合中。以下是几种常见的实现类及其添加元素的方式: #### 使用 `ArrayList` 添加元素 `ArrayList` 是 `List` 的一种具体实现,支持动态数组的功能。可以通过其 `add()` 方法来添加元素。 ```java import java.util.ArrayList; public class Example { public static void main(String[] args) { ArrayList<String> list = new ArrayList<>(); list.add("Element1"); // 添加字符串类型的元素 list.add("Element2"); System.out.println(list); } } ``` 此代码展示了如何通过 `add()` 方法向 `ArrayList` 集合中添加元素[^3]。 #### 使用 `HashSet` 添加元素 `HashSet` 实现了 `Set` 接口,它不允许重复的元素存在。同样可以使用 `add()` 方法来添加元素。 ```java import java.util.HashSet; public class HashSetExample { public static void main(String[] args) { HashSet<Integer> set = new HashSet<>(); set.add(1); // 添加整数类型的元素 set.add(2); set.add(2); // 尝试添加重复元素,不会生效 System.out.println(set); } } ``` 注意,在尝试添加已存在的元素时,`HashSet` 不会抛出异常,而是简单地忽略该操作[^1]。 #### 使用 `TreeSet` 添加元素 `TreeSet` 提供了一种基于红黑树的数据结构存储集合中的元素,并保持自然顺序或自定义顺序排列。如果要添加的对象未实现 `Comparable` 接口,则需要提供比较器。 ```java import java.util.TreeSet; public class TreeSetExample { public static void main(String[] args) { TreeSet<String> treeSet = new TreeSet<>(); // 默认按字典序排序 treeSet.add("Apple"); treeSet.add("Banana"); treeSet.add("Orange"); System.out.println(treeSet); try { TreeSet<Object> invalidSet = new TreeSet<>(); invalidSet.add("String"); // String 和 Integer 类型不兼容 invalidSet.add(1); } catch (ClassCastException e) { System.err.println("Error: " + e.getMessage()); } } } ``` 上述代码演示了当试图向 `TreeSet` 插入不同数据类型对象时可能引发的 `ClassCastException` 错误[^4]。 #### 总结 无论是哪种具体的集合实现形式,只要它们实现了 `Collection` 接口,就可以利用统一的方法——`add()` 来完成新成员加入的操作。每种集合都有自己的特性决定了某些特定行为的发生机制以及约束条件。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

齊 天 大 聖

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值