浅谈在java中list集合的排序问题

来源:互联网 发布:au是什么软件 编辑:程序博客网 时间:2024/06/13 02:43

定义实体类:

public class Person {    private Integer  id;    private  String  name;    private  Integer  age;    public Integer getId() {        return id;    }    public void setId(Integer id) {        this.id = id;    }    public String getName() {        return name;    }    public void setName(String name) {        this.name = name;    }    public Integer getAge() {        return age;    }    public void setAge(Integer age) {        this.age = age;    }    public Person(Integer id, String name, Integer age) {        super();        this.id = id;        this.name = name;        this.age = age;    }    public Person() {        super();        // TODO Auto-generated constructor stub    }    @Override    public String toString() {        return "Person [id=" + id + ", name=" + name + ", age=" + age + "]";    }}

测试类Test:

public static void main(String[] args) {    List<Person> list=new ArrayList<Person>(50);    list.add(new Person(1, "张三", 21));    list.add(new Person(2, "李四", 20));    list.add(new Person(3, "王五", 23));    list.add(new Person(4, "八戒", 22));    System.out.println(list);

这是会输出对应的值
在java中所有的集合实现类都已经重写toString()方法,不会输出地址
问题:
1.根据编号从大到小排序
2.根据年龄从小到大排序
3.根据姓名排序(中文)
一、第一个问题:
编号问题,在java中有Collections.sort()方法
其中里面的参数采用了重载

这里写图片描述

其中第二个中的方法参数使用泛型中的下限(super)用法,把list放进去会报错:报实体类Person的问题
其实sort()它要调用一个compareTo()方法
首先实现Comparable接口(加泛型Person)
这个时候实现方法

@Override    public int compareTo(Person o) {        // 根据id排序        if(this.id>o.id) return -1;        else if(this.id<o.id) return 1;        return 0;    }

这个时候会发现不会报错,输出即可

Person1 [id=4, name=八戒, age=22]Person1 [id=3, name=王五, age=23]Person1 [id=2, name=李四, age=20]Person1 [id=1, name=张三, age=21]

二、第二个问题:
年龄问题,有人会说,把id里面的值改一下就可以,但是如果还要比id呢??这种方法不可行,,这时候就可以使用
Collections.sort()中的重载
这里写图片描述
这个时候我们就需要再写一个写AgeSort

public class AgeSort implements Comparator<Person1> {    @Override    public int compare(Person1 o1, Person1o2) {        if(o1.getAge()>o2.getAge()) return 1;        else if(o1.getAge()< o2.getAge()) return -1;        return 0;    }}

直接在Test类中
Collections.sort(list, new AgeSort());输出即可

Person1 [id=2, name=李四, age=20]Person1 [id=1, name=张三, age=21]Person1 [id=4, name=八戒, age=22]Person1 [id=3, name=王五, age=23]

三、第三个问题:
姓名问题,再创建一个NameSort类

public class NameSort implements Comparator<Person1> {    @Override    public int compare(Person1 o1, Person1 o2) {        return java.text.Collator.getInstance(Locale.CHINESE).compare(o1.getName(), o2.getName());    }}

再次输出为:

Person1 [id=4, name=八戒, age=22]Person1 [id=2, name=李四, age=20]Person1 [id=3, name=王五, age=23]Person1 [id=1, name=张三, age=21]

总结:
1.接口的好处:一个接口有多个实现类,在java中,当参数为接口时,一般都传的是它对应的实现类
2.处理中文排序的问题,使用对应的java包java.text.Collator.getInstance(Locale.CHINESE)
java.text包还可以处理时间转化问题等等(java.text.SimpleDateFormat)

原创粉丝点击