4,java list排序的2中方法

1. 利用Collections类的 java.util.Collections.sort(java.util.List, java.util.Comparator) 方法,自定义比较器对象对指定对象进行排序

对学生对象按照其 分数(降序)进行排序,当分数相同时按学号(从小到大)排序,代码如下:

Student类

class Student{
    private int id;
    private String name;
    private float score;    //成绩
    
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public float getScore() {
        return score;
    }
    public void setScore(float score) {
        this.score = score;
    }
}

比较器类

//先按成绩 降序 排序,如果成绩一样的话按id 升序 排序
class StudentComparator implements Comparator{

    /**
      * return a negative integer, zero, or a positive integer as the first argument is less than, 
      *             equal to, or greater than the second. 
      */
    @Override
    public int compare(Student s1, Student s2) {
        
        if(s1.getScore()>s2.getScore()){    //greater
            return -1;
        }else if(s1.getScore()==s2.getScore()){ //equals
            if(s1.getId()>s2.getId()){
                return 1;
            }else if(s1.getId()==s2.getId()){
                return 0;
            }else{
                return -1;
            }
        }else{  //less
            return 1;
        }
    }
}

Demo测试类

public class ListSortDemo {

    public static void main(String[] args) {
        
        Student s1 = new Student();
        s1.setId(10001);
        s1.setName("cat");
        s1.setScore(99.5f);
        
        Student s2 = new Student();
        s2.setId(10008);
        s2.setName("bba");
        s2.setScore(100.0f);
        
        Student s3 = new Student();
        s3.setId(10011);
        s3.setName("bac");
        s3.setScore(89.5f);
        
        Listlist = new ArrayList();
        list.add(s1);
        list.add(s2);
        list.add(s3);
        
        System.out.println("排序之前-----------------------");
        for(Student stu:list){
            System.out.println("id="+stu.getId()+" name="+stu.getName()+" score="+stu.getScore());
        }
        
        Collections.sort(list, new StudentComparator());    //排序
        
        System.out.println("排序之后-----------------------");
        for(Student stu:list){
            System.out.println("id="+stu.getId()+" name="+stu.getName()+" score="+stu.getScore());
        }
    }
}

排序之前-----------------------
id=10001 name=cat score=99.5
id=10008 name=bba score=100.0
id=10011 name=bac score=89.5
排序之后-----------------------
id=10008 name=bba score=100.0
id=10001 name=cat score=99.5
id=10011 name=bac score=89.5


  1. 通过实现Comparable接口来实现list的排序
    假如现在我们有一个Person类的list集合,要让其按照一个Order属性进行排序,我们可以让Person类实现Comparable接口,重写其CompareTo方法即可,可以让程序按照我们想要的排列方式进行排序,如:这里我让Person按照order属性升序排序,具体实现如下:

Person实体类

public class Person implements Comparable{
    private String name;
    private Integer order;
 
    /**
     * @return the name
     */
    public String getName() {
        return name;
    }
 
    /**
     * @param name
     *            the name to set
     */
    public void setName(String name) {
        this.name = name;
    }
 
    /**
     * @return the order
     */
    public Integer getOrder() {
        return order;
    }
 
    /**
     * @param order
     *            the order to set
     */
    public void setOrder(Integer order) {
        this.order = order;
    }
 

    @Override
    public int compareTo(Person arg0) {
        return this.getOrder().compareTo(arg0.getOrder());      //这里定义你排序的规则。
    }
 }

测试类

public static void main(String[] args) {
    //初始化数据
    ListlistA = new ArrayList();
    Person p1 = new Person();
    Person p2 = new Person();
    Person p3 = new Person();
 
    p1.setName("name1");
    p1.setOrder(1);
    p2.setName("name2");
    p2.setOrder(2);
    p3.setName("name3");
    p3.setOrder(3);
 
    listA.add(p2);
    listA.add(p1);
    listA.add(p3);

    //排序
    Collections.sort(listA);

    //打印排序后的Person
    for (Person p : listA) {
        System.out.println(p.getName());
    }
}
结果:
name1
name2
name3
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 项目中经常会遇到列表搜索查询,大部分的查询是可以通过sql语句来实现的,有些特殊的搜索排序sql则实现不了,例如中...
    信徒_allen阅读 2,608评论 0 1
  • List:对付顺序的好帮手 List接口存储一组不唯一(可以有多个元素引用相同的对象),有序的对象 Set:注重独...
    Java面试指南阅读 4,616评论 0 2
  • javascript中的所有事物都是对象 : 字符串 数值 数组 函数.... 此外, javascript允许自...
    hugoWang1018阅读 341评论 0 3
  • 夜跑跟夜爬一样,夜里总是更容易让自己专注在这件事情上。 尽管目前为止,我只夜爬过两次:一次是傍晚做大巴去到山脚下,...
    听风看树望天空阅读 305评论 0 0
  • “课眼”,好比蛇的七寸,承上启下,是要害中的要害。 1.业绩是管理活动的关键变量 为什么这样说?管理学的核心,是要...
    天悦刘洋阅读 975评论 0 0