java 集合排序方法_java中Collections.sort()方法实现集合排序

1.Integer/String泛型的List进行排序

List integerlist = new ArrayList();   //定义一个Integer泛型的List

然后用add()方法添加一些Integer类型的数据到该List中,

Collections.sort(integerlist);                                //因为是数值型的数据,排序即按照大小升序排序

2.自定义泛型的List进行排序

其实Collections.sort(List)方法进行排序的前提是:List对象中的泛型类实现了Comparable接口;

我们拿学生类来用具体的代码演示一下:

public class StudentimplementsComparable{

int id;

String name;

........

public int compareTo(Student o){               //实现接口自然要实现接口的方法

return  this.id.compareTo(o.id);      //规定学生对象排序的依据,这里按ID排序

}

}

然后就可以对一个由学生对象组成的List表进行Collections.sort(List)排序了(其实是按ID排序)

Comparable接口定义的规则是默认规则。

3.Comparator接口

这个接口可以帮助我们事先定义好各种比较规则,用的时候直接换规则,不用去改泛型对象里

的比较方法compareTo(),

ID排序规则(类):

public class comparebyidimplementsComparator{

public int compare(Student o1,Student o2){

return o1.id.compareTo(o2.id);

}

}

Name排序规则(类):

public class comparebynameimplementsComparator{

public int compare(Student o1,Student o2){

return o1.name.compareTo(o2.name);

}

}

规则定义好了,如何使用呢?

先实例化一个规则对象,将对象传入Collections.sort()方法中:

Collections.sort(studentlist,new comparebyname());

这样就能忽略上面的默认规则,实现按照新的规则(姓名排序)排序了。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值