java后台实现自定义排序_[Java教程]JAVA 使用Comparator接口实现自定义排序

[Java教程]JAVA 使用Comparator接口实现自定义排序

0 2018-10-19 16:00:59

1、原则

Comparator接口可以实现自定义排序,实现Comparator接口时,要重写compare方法:

int compare(Object o1, Object o2) 返回一个基本类型的整型

如果要按照升序排序,则o1 小于o2,返回-1(负数),相等返回0,01大于02返回1(正数)

如果要按照降序排序,则o1 小于o2,返回1(正数),相等返回0,01大于02返回-1(负数)1 import java.util.ArrayList; 2 import java.util.Comparator; 3 import java.util.List; 4 5 public class UserComparator implements Comparator < User > { 6 7 public static void main( String[] args ) { 8 List < User > users = new ArrayList < User >(); 9 users.add( new User( 10, "a" ) );10 users.add( new User( 11, "d" ) );11 users.add( new User( 15, "s" ) );12 users.add( new User( 6, "x" ) );13 users.add( new User( 17, "a" ) );14 users.add( new User( 17, "b" ) );15 users.add( new User( 17, "c" ) );16 users.add( new User( 17, "d" ) );17 UserComparator comparator = new UserComparator();18 19 users.sort( comparator );20 // 也可以使用:Collections.sort( users, comparator );21 22 for ( User u : users ) {23 System.out.println( u );24 }25 }26 27 @Override28 public int compare( User u1, User u2 ) {29 if ( u1.equals( u2 ) ) {30 return 0;31 }32 else if ( u1.getAge() < u2.getAge() ) {33 return 1;34 }35 else if ( u1.getAge() == u2.getAge() ) {36 int f = u1.getName().compareTo( u2.getName() );37 if ( f < 0 ) {38 return -1;39 }40 return 0;41 }42 else {43 return -1;44 }45 }46 }47 48 class User {49 private int age;50 private String name;51 52 public User() {53 54 }55 56 public User( int age, String name ) {57 this.age = age;58 this.name = name;59 }60 61 public int getAge() {62 return age;63 }64 65 public void setAge( int age ) {66 this.age = age;67 }68 69 public String getName() {70 return name;71 }72 73 public void setName( String name ) {74 this.name = name;75 }76 77 @Override78 public String toString() {79 return "User [age=" + age + ", name=" + name + "]";80 }81 82 }User [age=17, name=a]User [age=17, name=b]User [age=17, name=c]User [age=17, name=d]User [age=15, name=s]User [age=11, name=d]User [age=10, name=a]User [age=6, name=x]

本文网址:http://www.shaoqun.com/a/447980.html

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们:admin@shaoqun.com。

JAVA

0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值