Java Collections集合工具类的方法

集合工具类

添加多个元素、打乱集合顺序

sort方法【两种实现方式】

方法1:

默认是升序排序

只能传List集合不能传Set集合

自定义类型要重写接口的实现类中的compareTo方法,并且只能在实现类中重写,不能使用匿名内部类重写

package Collections;

public class Person implements Comparable<Person>{
    private String name;
    private int age;

    public Person() {
    }

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

    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;
    }

    @Override
    public int compareTo(Person person) {
        // 比较两个人的年龄 this和参数person
        return person.getAge() - this.getAge();
//        return person.getAge() - this.getAge();
    }
}

使用

Collections.sort(list1);

方法2:

自定义类型排序的第二种写法 使用匿名内部类重写其中的compare方法 ,且只能使用匿名内部类

两种方法的区别:

比较基本类型

比较自定义类型

多个条件判断 ,年龄相等按照姓名进行排序

package Collections;

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

public class TestMain {
    public static void main(String[] args) {
        ArrayList<Integer> list1 = new ArrayList<>();
        Collections.addAll(list1,4,5,8,9,7,5,2,5,7);
        System.out.println(list1);
        // 默认是升序排序
        Collections.sort(list1);
        System.out.println(list1);
        ArrayList<Person> list2 = new ArrayList<>();
        list2.add(new Person("zhang",11));
        list2.add(new Person("zhang",45));
        list2.add(new Person("zhang",19));
        System.out.println(list2);
        Collections.sort(list2, new Comparator<Person>() {// 传的是一个接口 需要覆盖重写compare方法
            @Override
            public int compare(Person student, Person t1) {
                return student.getAge()-t1.getAge(); // 按照年龄升序排序
            }
        });
        System.out.println(list2);

    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值