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

作者:龙凌云端 时间:2022-01-28 03:59:16 

这篇文章主要介绍了如何基于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}

来源:https://www.cnblogs.com/miracle-luna/p/12181535.html

标签:Java,对象,List,排序
0
投稿

猜你喜欢

  • SpringCloud搭建netflix-eureka微服务集群的过程详解

    2023-09-02 18:11:52
  • C#带你玩扫雷(附源码)

    2021-11-04 05:54:23
  • 解析Java的Hibernate框架中的持久化类和映射文件

    2023-08-19 15:00:05
  • springboot自定义Starter的具体流程

    2022-01-26 05:08:06
  • 一篇文章带你从java字节码层理解i++和++i

    2023-05-29 13:57:58
  • Java 数据结构与算法系列精讲之哈希算法实现

    2022-01-10 23:56:07
  • Java多线程yield心得分享

    2023-11-29 05:58:15
  • 详解Java中final的用法

    2022-09-22 10:20:32
  • Java 常见的限流算法详细分析并实现

    2022-01-05 22:11:09
  • JDBC连接MySQL并实现模糊查询

    2021-07-06 01:42:28
  • 【java 多线程】守护线程与非守护线程的详解

    2023-11-29 01:35:29
  • Redis集群原理详细分析

    2021-08-06 07:34:00
  • Java实现特定范围的完数输出算法示例

    2023-11-29 00:43:45
  • 详解C++ STL模拟实现forward_list

    2023-06-21 02:36:04
  • 详解Java中的数组与字符串相关知识

    2023-02-10 03:31:10
  • 基于Flutter实现多边形和多角星组件

    2023-06-19 06:02:50
  • IntelliJ IDEAx导出安卓(Android)apk文件图文教程

    2022-06-22 18:26:16
  • Java设计模式中的观察者模式

    2021-08-22 01:27:20
  • flutter窗口初始和绘制流程详析

    2023-08-17 21:07:30
  • Android实现双曲线折线图

    2023-07-29 15:07:28
  • asp之家 软件编程 m.aspxhome.com