温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Java实现对象List排序的案例

发布时间:2021-02-01 14:09:43 来源:亿速云 阅读:216 作者:小新 栏目:编程语言

这篇文章给大家分享的是有关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}

感谢各位的阅读!关于“Java实现对象List排序的案例”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI