2020--10-21-Collections工具类中常用的方法

COllections工具类

java.util.Collections 是对集合进行操作的工具类,里边含有大量的静态方法

addAll()和shuffle()方法

前者是往集合中添加一些元素(多个),后者是将集合中元素的顺序打乱。类似于纸牌游戏的洗牌功能

import java.util.ArrayList;
import java.util.Collections;

/**
 * Collections 工具类
 *      public static <T> boolean addAll(Collection<T> , T...elements):往集合中添加元素
 *      public static shuffle( List <?> list)打乱顺序:打乱集合顺序
 *
 * @author HolyTrees
 * @date 2020-10-21  下午 14:45
 */
public class DemoCollections {
    public static void main(String[] args) {
        ArrayList<String> list = new ArrayList<>();
        /**
         * 往集合中添加元素
         */
        Collections.addAll(list,"a","b","c","d","e");
        System.out.println("初始元素顺序的集合");
        System.out.println(list);
        System.out.println();
        /**
         * 打乱集合中元素的顺序
         */
        Collections.shuffle(list);
        System.out.println("打乱元素顺序后的集合");
        System.out.println(list);
        System.out.println();
        /**
         * 将指定的元素和参数元素进行替换
         */
        Collections.replaceAll(list,"a","k");
        System.out.println("元素替换后的集合");
        System.out.println(list);
    }
}
输出结果
初始元素顺序的集合
[a, b, c, d, e]

打乱元素顺序后的集合
[e, a, c, b, d]

元素替换后的集合
[e, k, c, b, d]

sort()方法

用于给集合中的元素进行排序

public static void sort(List list):将集合中的元素按照默认规则排序

如果要用自定义的对象进行排序,那么该类要继承Comparable接口,并且要重写接口中的CompareTo方法;才能实现对自定义的对象进行排序;

自定义一个CollectionPerson类,继承Comparable接口,重写compareTo方法
重写toString方法():否则打印集合得到的是集合中元素的地址值
/**
 * 用自定义的类型进行排序
 * @author HolyTrees
 * @date 2020-10-21  下午 15:06
 */
public class CollectionPerson implements Comparable<CollectionPerson>{
    /**
     * 定义成员变量 name age
     */
    private String name;
    private int age;

    public CollectionPerson() {
    }

    public CollectionPerson(String name, int age) {
        this.name = name;
        this.age = age;
    }

    /**
     * 获取方法
     * @return
     */

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    /**
     * 重写toString方法
     * @return
     */
    @Override
    public String toString() {
        return "CollectionPerson{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }


    /**
     * 重写的compareTo方法
     * @param o
     * @return
     */
    @Override
    public int compareTo(CollectionPerson o) {
        /**
         * return 0;认为两个参数相同
         * 自定义比较规则,比较两个人的年龄(this,参数CollectionPerson)
         * return this.getAge()-o.getAge() 升序排序
         * return o.getAge() - this.getAge() 降序排序
         */
        return o.getAge()-this.getAge();
    }
}
下面进行测试
import java.util.ArrayList;
import java.util.Collections;

/**
 * public static <T> boolean addAll(Collection<T> , T...elements):往集合中添加元素
 * public static shuffle( List <?> list)打乱顺序:打乱集合顺序
 * public static <T> void sort(list <T> list):将集合按照默认规则排序;
 *      sort使用前提:被排序的集合里面存储的元素必须实现Comparable,重写接口中的方法compareTo方法定义的规则;
 *      CompareTo方法排序规则:
 *          (this). - 参数:升序
 *          反之则降序
 *
 * @author HolyTrees
 * @date 2020-10-21  下午 14:58
 */
public class DemoCollectionsSort {
    public static void main(String[] args) {
        ArrayList<String>list = new ArrayList<>();
        /**
         * 添加元素
         */
        Collections.addAll(list,"a","c","d","e","f");
        System.out.println(list);
        /**
         * 打乱元素顺序
         */
        System.out.println("打乱元素顺序");
        Collections.shuffle(list);
        System.out.println(list);
        /**
         * 默认顺序排序
         */
        Collections.sort(list);
        System.out.println("默认方式排序:");
        System.out.println(list);
        System.out.println();

        /**
         * 自定义的类型进行排序
         */
        ArrayList<CollectionPerson> personList = new ArrayList<>();
        personList.add(new CollectionPerson("张三",18));
        personList.add(new CollectionPerson("李四",20));
        personList.add(new CollectionPerson("王五",19));

        System.out.println("集合初始顺序");
        System.out.println(personList);
        System.out.println();
        System.out.println("采用自定义降序排序:");
        Collections.sort(personList);
        System.out.println(personList);
    }
}

输出结果:
[a, c, d, e, f]
打乱元素顺序
[d, f, e, c, a]
默认方式排序:
[a, c, d, e, f]

集合初始顺序
[CollectionPerson{name='张三', age=18}, CollectionPerson{name='李四', age=20}, CollectionPerson{name='王五', age=19}]

采用自定义降序排序:
[CollectionPerson{name='李四', age=20}, CollectionPerson{name='王五', age=19}, CollectionPerson{name='张三', age=18}]

public static void sort(List list,Comparator<? super T>):将集合中的元素按照指定规则排序;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;

/**
 * @author HolyTrees
 * @date 2020-10-21  下午 16:01
 */
public class DemoWork {
    public static void main(String[] args) {
        ArrayList<Integer>list = new ArrayList<>();
        /**
         * 添加元素
         */
        Collections.addAll(list,51,22,46,93,72,19);
        System.out.println(list);
        System.out.println();
        /**
         * 打乱顺序
         */
        Collections.shuffle(list);
        System.out.println("打乱顺序后的集合");
        System.out.println(list);
        System.out.println();
        /**
         * 升序排序
         */
        Collections.sort(list);
        System.out.println("升序排序");
        System.out.println(list);
        System.out.println();
        /**
         * 降序排序,使用匿名对象重写此方法
         */
        Collections.sort(list, new Comparator<Integer>() {
            /**
             * o2 - o1降序
             * o1 - o2升序
             * @param o1
             * @param o2
             * @return
             */
            @Override
            public int compare(Integer o1, Integer o2) {
                return o2 - o1;
            }
        });
        /**
         * 重写后的降序排序
         */
        System.out.println("采用重写后的方法排序");
        System.out.println(list);
    }
}

[51, 22, 46, 93, 72, 19]

打乱顺序后的集合
[22, 93, 72, 51, 19, 46]

升序排序
[19, 22, 46, 51, 72, 93]

采用重写后的方法排序
[93, 72, 51, 46, 22, 19]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值