如何基于Java实现对象List排序

这篇文章主要介绍了如何基于Java实现对象List排序,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

按照对象中的某个属性,对对象List进行排序。

以初唐四杰的成绩排名为例,对诗人进行排序。

Java实现如下:

1、诗人(Poet)类结构,定义如下:

/**
 * Created by Miracle Luna on 2020/1/11
 */
public class Poet {
  private String name;
  private Double score;

  public Poet(String name, Double score) {
    this.name = name;
    this.score = score;
  }

  public String getName() {
    return name;
  }

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

  public Double getScore() {
    return score;
  }

  public void setScore(Double score) {
    this.score = score;
  }

  @Override
  public String toString() {
    return "Poet{" +
        "name='" + name + '\'' +
        ", score=" + score +
        '}';
  }
}

2、诗人按照成绩排名,代码如下:

import java.util.ArrayList;
import java.util.Comparator;
import java.util.List;

/**
 * Created by Miracle Luna on 2020/1/11
 */
public class PoetSort {

  public static void main(String[] args) {
    List<Poet> poetList = new ArrayList<Poet>();
    Poet poet1 = new Poet("杨炯", 94.0);
    poetList.add(poet1);
    Poet poet2 = new Poet("卢照邻", 92.5);
    poetList.add(poet2);
    Poet poet3 = new Poet("骆宾王", 95.0);
    poetList.add(poet3);
    Poet poet4 = new Poet("王勃", 99.5);
    poetList.add(poet4);

    // 初始顺序
    System.out.println("==> 初始顺序如下:");
    poetList.forEach(poet -> System.out.println(poet.toString()));

    // 按照分数排名(从高到低)
    poetList.sort(new Comparator<Poet>() {
      @Override
      public int compare(Poet poet1, Poet poet2) {
        Double score1 = poet1.getScore();
        Double score2 = poet2.getScore();
        return score2.compareTo(score1);
      }
    });
    System.out.println("\n==> 按照分数排名(从高到低)如下:");
    poetList.forEach(poet -> System.out.println(poet.toString()));

    // 按照分数排名(从低到高)
    poetList.sort(new Comparator<Poet>() {
      @Override
      public int compare(Poet poet1, Poet poet2) {
        Double score1 = poet1.getScore();
        Double score2 = poet2.getScore();
        return score1.compareTo(score2);
      }
    });
    System.out.println("\n==> 按照分数排名(从低到高)如下:");
    poetList.forEach(poet -> System.out.println(poet.toString()));
  }
}

3、运行结果如下:

==> 初始顺序如下:
Poet{name='杨炯', score=94.0}
Poet{name='卢照邻', score=92.5}
Poet{name='骆宾王', score=95.0}
Poet{name='王勃', score=99.5}

==> 按照分数排名(从高到低)如下:
Poet{name='王勃', score=99.5}
Poet{name='骆宾王', score=95.0}
Poet{name='杨炯', score=94.0}
Poet{name='卢照邻', score=92.5}

==> 按照分数排名(从低到高)如下:
Poet{name='卢照邻', score=92.5}
Poet{name='杨炯', score=94.0}
Poet{name='骆宾王', score=95.0}
Poet{name='王勃', score=99.5}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Java按照List内存储的对象的某个字段进行排序的实例

    关键点:将List内存储的对象实现Comparable类,重写它的compareTo()方法即可 Bean: package chc; public class StuVo implements Comparable<StuVo>{ private String id; private String name; private Integer age; public StuVo(String id, String name, Integer age) { this.id=id; this.na

  • java实现List中对象排序的方法

    本文实例讲述了java实现List中对象排序的方法.分享给大家供大家参考,具体如下: package com.test; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; public class NewsManager { /** * @param args */ public static void main(String[

  • java根据List内对象的属性排序方法

    方法一:实现Comparator接口,并重写compare方法 实体类代码: import java.util.Comparator; /** * 学生类 方法一 * 实现Comparator接口 * 并重写compare方法 * @author liaot * */ public class Student implements Comparator<Student>{ private String name; //姓名 private int age; //年龄 //重写 比较方法 本次例

  • 详解Java8新特性Stream之list转map及问题解决

    List集合转Map,用到的是Stream中Collectors的toMap方法:Collectors.toMap 具体用法实例如下: //声明一个List集合 List<Person> list = new ArrayList(); list.add(new Person("1001", "小A")); list.add(new Person("1002", "小B")); list.add(new Person

  • java8快速实现List转map 、分组、过滤等操作

    利用java8新特性,可以用简洁高效的代码来实现一些数据处理. 定义1个Apple对象: public class Apple { private Integer id; private String name; private BigDecimal money; private Integer num; public Apple(Integer id, String name, BigDecimal money, Integer num) { this.id = id; this.name =

  • java中List对象排序通用方法

    本文实例讲述了java中List对象排序通用方法.分享给大家供大家参考.具体分析如下: 在数据库中查出来的列表list中,往往需要对不同的字段重新排序,一般的做法都是使用排序的字段,重新到数据库中查询.如果不到数据库查询,直接在第一次查出来的list中排序,无疑会提高系统的性能. 只要把第一次查出来的结果存放在session中,就可以对list重新排序了.一般对list排序可以使用Collections.sort(list),但如果list中包含是一个对象的话,这种方法还是行不通的.那要怎么排序

  • java ArrayList集合中的某个对象属性进行排序的实现代码

    开发中有时候需要自己封装分页排序时,List如何对某一属性排序呢,分享一个小实例,大家共勉,希望能对大家有用,请多多指教. 1.Student的Bean如下: public class Student { private int age; private String name; private String weight; public String getWeight() { return weight; } public void setWeight(String weight) { th

  • Java使用Collections工具类对List集合进行排序

    这篇文章主要介绍了Java使用Collections工具类对List集合进行排序,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 一.说明 使用Collections工具类的sort方法对list进行排序 新建比较器Comparator 二.代码 排序: import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import jav

  • java实现ArrayList根据存储对象排序功能示例

    本文实例讲述了java实现ArrayList根据存储对象排序功能.分享给大家供大家参考,具体如下: 与c++中的qsort的实现极为相似,构建新的比较对象Comparator即可 package demo; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; class Stu{ public int age; private String name; public Stu(

  • java中List对象列表实现去重或取出及排序的方法

    前言 因为在面试的时候碰到几次list的去重和排序,觉着有必要给大家总结一下具体的方法,分享出来供大家学习参考,话不多说了,来一起看看下面介绍的一种做法: 一.list去重 1.1 实体类Student List<Student>容量10k以上,要求去重复.这里Student的重复标准是属性相同,因此需要重写equals和hashcode方法,不知道有几个可以手写出来. student的equals方法: public void equals(Object o){ if(this == o)

随机推荐