Java集合之 Collection接口

Collection 接口用于表示无序、允许重复的集合。

构建 Collection 对象

使用 Collection 接口定义变量,使用 new 创建具体的实现类。
Collection co=new ArrayList();
由于使用接口定义变量,所以可以 new 任何 Collection 接口的实现 类,例如 HashSet Vector LinkedList 等【多态性】

1、int size();

获取集合中的存储元素个数,由于具体实现类的区别,所以 size 不一定是添加元素个数 。

数组中实际上是不能直接获取其中存储的元素个数,集合中可以分为两个概念:容积 capacity 是表示可以存放 的元素个数,类似于集合的 length size 表示实际存储的元素个数。

2、boolean add(E e);

向集合中添加元素 e。

3、boolean isEmpty();

判断集合中的元素个数是否为 0,不能使用这个方法判断引用对象是否为 null 。

注意:只判断集合中是否没有元素,并不会判断集合是否为 null ,如果需要判断集合变量是否为 null ,需要自行编程实现,例如 Objects.nonNull(co) 或者 co!=null 。

4、boolean contains(Object o);

判断集合中是否包含指定元素 o,有 true 没有 false。不能判断集合中是否包含 null 元素。如果编程实现添加 add(null)则可以判断正确,默认添加的 null 并不能进行判断。

5、Iterator<E> iterator();

Iterable 接口中定义的方法,获取迭代器对象用于遍历集合中的所有元素。

遍历 Collection 集合中元素的写法:
public class Test {
    public static void main(String[] args) {
        Collection co = new ArrayList();
        ThreadLocalRandom r = ThreadLocalRandom.current();
        for (int i = 0; i < 10; i++)
            co.add(r.nextInt(100)); //自动装箱

        //1、可以使用 Iterable 接口提供的获取 Iterator 对象进行遍历访问
        Iterator it = co.iterator(); //可以将迭代器理解为一个指向集合元素的指针
        while (it.hasNext()) { // 判断当前指针所指向的位置后续是否有元素,有 true 没有 false
            Object ele = it.next();//位置指针后移,并获取位置指针所指向的元素
            System.out.println(ele);
            ele = 111; // 通过迭代器直接修改集合元素无效,除非是原地修改
        }

        //2、使用 Iterator 的 forEachRemaining 方法遍历集合中的所有元素
        it = co.iterator();
        it.forEachRemaining((Object obj) -> {
            System.out.println(obj);
            obj = 222; // 通过迭代器直接修改集合元素无效,除非是原地修改
        });

        //3、使用 Collection 接口的父接口 Iterable 中的方法 forEach
        co.forEach((Object obj) -> {
            System.out.println(obj);
            obj = 333; // 直接修改集合元素无效,除非是原地修改
        });

        //4、foreach 结构
        for (Object tmp : co) {
            System.out.println(tmp);
            tmp = 444; // 直接修改集合元素无效,除非是原地修改
        }
    }
}

6、Object[] toArray();

将集合转换为 Object 类型的数组。

7、<T> T[] toArray(T[] a);

使用泛型将集合转换为特定类型的数组。

8、boolean remove(Object obj);

从集合中删除指定的元素 obj,如果删除成功 true 否则 false。

9、default boolean removeIf(Predicate<? super E> filter)

判断集合是否删除过数据,删除了返回 true, 否则 false。

10、void clear();

清空集合中的所有元素。
  • 7
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
掌握集合的概念、体系结构、分类及使用场景 2)了解Set接口及主要实现类(HashSet、TreeSet) 3)了解List接口及主要实现类(ArrayList、LinkedList、Vector) 4)了解Map接口及主要实现类(HashMap、TreeMap、HashTable) 二、实验内容及步骤 1、编写程序练习将以下5个Person类的对象放在一个HashSet中。 姓名:张三 身份证号:178880001 姓名:王五 身份证号:178880002 姓名:李四 身份证号:178880003 姓名:王五 身份证号:178880002 姓名:李四 身份证号:178880004 注意:因为Person类是自定义类,需要重写hashCode()方法和equals()方法,并规定只有姓名和身份证号都相等,则对象相等。 其中计算哈希码的算法:(31 + ((name == null) ? 0 : name.hashCode()))*31 + id (注:name:Person对象的姓名,id:Person对象的身份证号) 主方法中作如下测试: 1)创建一个可放置Person类对象的HashSet; 2)依次添加上述5个对象到HashSet中; 3)把集合中的元素打印出来(使用迭代器Iterator) 2、编写程序练习List集合的基本使用: 1) 创建一个只能容纳String对象名为names的ArrayList集合; 2)按顺序往集合中添加5个字符串对象:"张三"、"李四"、"王五"、"马六"、"赵七"; 3)对集合进行遍历,分别打印集合中的每个元素的位置与内容; 4)打印集合的大小,然后删除集合中的第3个元素,并显示删除元素的内容,然后再打印目前集合中第3个元素的内容,并再次打印集合的大小。 3、编写程序练习Map集合的基本使用: 1)创建一个只能容纳String对象的person的HashMap集合; 2)往集合中添加5个"键-值"对象: "id"-"1"; "name"-"张三"; "sex"-"男"; "age"-"25"; "hobby"-"爱学Java" 3)对集合进行遍历,分别打印集合中的每个元素的键与值; 4)打印集合的大小,然后删除集合中的键为age的元素,并显示删除元素的内容,并再次打印集合的大小。 四、思考题 1、集合中的List、Set、Map有哪些不同? 2、为什么使用集合框架,而尽可能少用数组作为存储结构? 3、如何使用TreeSet实现第一题?

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值