Collections 工具类

17.1 Collections 工具类介绍

在这里插入图片描述

17.2 排序操作:(均为 static 方法)

在这里插入图片描述

**排序操作 **应用案例演示

//创建 ArrayList 集合,用于测试.-->元素可重复
        List list = new ArrayList();
        list.add("0");
        list.add("11");
        list.add("2");
        list.add("333");
        list.add("0");

        System.out.println("默认的list=" + list);
        // reverse(List):反转 List 中元素的顺序
        Collections.reverse(list);
        System.out.println("反转排序后:");
        System.out.println("list=" + list);

        //shuffle(List):对 List 集合元素进行随机排序
        System.out.println("随机排序后:");
        for (int i = 0; i < 2; i++) {
            Collections.shuffle(list);
            System.out.println("List=" + list);
        }

        //sort(List):根据元素的自然顺序对指定 List 集合元素按升序排序
        Collections.sort(list);
        System.out.println("自然排序后:");
        System.out.println("list=" + list);
        //sort(List, Comparator):根据指定的 Comparator 产生的顺序对 List 集合元素进行排序
        //我们希望按照 字符串的长度大小排序
        Collections.sort(list, new Comparator() {
            @Override
            public int compare(Object o1, Object o2) {
                //可以加入校验代码
                return ((String)o1).length() - ((String)o2).length();
            }
        });
        System.out.println("字符串长度大小排序=" + list);
        //swap(List, int, int):将指定 list 集合中的 i 处元素和 j 处元素进行交换

        //比如:将索引为 0 的元素和索引为 1 的元素交换
        Collections.swap(list,0,1);
        System.out.println("交换后的情况:");
        System.out.println("list=" + list);

17.3 查找、替换

在这里插入图片描述

**查找、替换 **应用案例演示

//Object max(Collection):根据元素的自然顺序,返回给定集合中的最大元素
        System.out.println("自然顺序最大元素=" + Collections.max(list));

        //Object max(Collection, Comparator):根据 Comparator 指定的顺序,返回给定集合中的最大元素
        //比如,我们要返回长度最大小的元素
        Object maxObject = Collections.max(list, new Comparator() {
            @Override
            public int compare(Object o1, Object o2) {
                return ((String)o1).length() - ((String)o2).length();
            }
        });
        System.out.println("长度最大的元素=" + maxObject);

        //Object min(Collection)
        System.out.println("自然顺序最小元素=" + Collections.min(list));
        //Object min(Collection, Comparator)
        //上面的两个方法,参考 max 即可

        //int frequency(Collection, Object):返回指定集合中指定元素的出现次数
        System.out.println(Collections.frequency(list,"0"));

        //void copy(List dest, List src):将 src 中的内容复制到 dest 中
        ArrayList dest = new ArrayList();
        //为了完成一个完整拷贝,我们需要先给 dest 赋值,大小和list.size()一样
        for (int i = 0; i < list.size(); i++) {
            dest.add("");
        }
        //拷贝
        Collections.copy(dest,list);
        System.out.println("dest=" + list);

        //boolean replaceAll(List list, Object oldVal, Object newVal):使用新值替换 List 对象的所有旧值
        //如果 list 中,有 0 就替换成 666
        Collections.replaceAll(list,"0","666");
        System.out.println("list 替换后=" + list);

集合完结~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

xjz_2002

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

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

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

打赏作者

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

抵扣说明:

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

余额充值