Collection工具类

Collection工具类的介绍

  • Collection 是一个操作Set、List和Map等集合的工具类
  • Collection中提供了一些列静态的方法对集合元素进行排序、查询和修改的等操作

Collection的排序操作(均为Static方法)

  • 1,reverse(List):反转List中元素的顺序
  • 2,shuffle(List):对List集合元素进行随机排序
  • 3,sort(List,Comparator):根据元素的自然顺序对指定的List集合元素按升序排序
  • 4,swap(List,int,int):将指定list集合中的i处元素和j处元素进行交换
  • 5,Object max(Collection):根据元素的自然顺序,返回给定集合中的最大元素
  • 6,Object min(Collection):参考5
  • 7,int frequency(Collection,Object):返回指定集合中指定元素的出现次数
  • 8,void copy(List dest,List src):将 src 中的内容复制到 dest 中
  • 9,boolean replaceAll(List list,Object oldVal,Object newVal):使用新值替换 List 对象的所有旧值
@SuppressWarnings({"all"})
public class Collections_ {
    public static void main(String[] args) {
        //创建ArrayList对象
        List list = new ArrayList();
        list.add("to");
        list.add("smith");
        list.add("king");
        list.add("tom");//可以重复

        System.out.println(list);

        //1,reverse(List):**反转**List中元素的顺序
        Collections.reverse(list);
        System.out.println("反转后的数组="+list);

        //2,shuffle(List):对List集合元素进行**随机排序**
        Collections.shuffle(list);
        System.out.println("随机排序后的数组="+list);

        //3,sort(List,Comparator):根据元素的自然顺序对指定的List集合元素按**升序排序**
        Collections.sort(list);
        System.out.println("自然排序后的数组="+list);
        //sort(List,Comparator):根据指定的Comparator产生的顺序对List集合元素进行排序
        Collections.sort(list, new Comparator() {
            @Override
            public int compare(Object o1, Object o2) {
                return ((String)o2).length()-((String)o1).length();
            }
        });
        System.out.println("根据字符串长度大小排序,从大到小排序"+list);

        //4,swap(List,int,int):将指定list集合中的i处元素和j处元素进行**交换**
        Collections.swap(list,1,2);
        System.out.println("交换后的list="+list);

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

        //6,Object min(Collection)
        //Object min(Collection,Comparator)
        //上面的两个方法,参考 max 即可

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

        //8,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="+dest);

        //9,boolean replaceAll(List list,Object oldVal,Object newVal):使用新值替换 List 对象的所有旧值
        Collections.replaceAll(list,"tom","汤姆");
        System.out.println("list替换后="+list);

    }
}

结果
在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值