博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java List 排序 Collections.sort() 对 List 排序
阅读量:5328 次
发布时间:2019-06-14

本文共 1440 字,大约阅读时间需要 4 分钟。

实体类:

class User { String name; String age;  public User(String name,String age){  this.name=name;  this.age=age; } public String getAge() {  return age; } public void setAge(String age) {  this.age = age; } public String getName() {  return name; } public void setName(String name) {  this.name = name; } }

具体的比较类,实现Comparator接口:

import java.util.Comparator;import java.util.List;import java.util.ArrayList;import java.util.Collections;public class ComparatorUser implements Comparator{ public int compare(Object arg0, Object arg1) {  User user0=(User)arg0;  User user1=(User)arg1;   //首先比较年龄,如果年龄相同,则比较名字  int flag=user0.getAge().compareTo(user1.getAge());  if(flag==0){   return user0.getName().compareTo(user1.getName());  }else{   return flag;  }   } }

测试类:

public class SortTest {  public static void main(String[] args){  List userlist=new ArrayList();  userlist.add(new User("dd","4"));  userlist.add(new User("aa","1"));  userlist.add(new User("ee","5"));  userlist.add(new User("bb","2"));    userlist.add(new User("ff","5"));  userlist.add(new User("cc","3"));  userlist.add(new User("gg","6"));    ComparatorUser comparator=new ComparatorUser();  Collections.sort(userlist, comparator);     for (int i=0;i

首先年龄排序,如果年龄相同,则按名字排序。

结果:

   1, aa
   2, bb
   3, cc
   4, dd
   5, ee                    //注意:同样是5岁的人,则比较名字(ee,ff),然后排序
   5, ff
   6, gg

java Collections.sort实现的排序默认是升序排序。既然知道默认是升序了,那么转换下两个Object的位置就变成降序排序。

转载于:https://www.cnblogs.com/longshiyVip/p/4777024.html

你可能感兴趣的文章
提高开发效率的十五个Visual Studio 2010使用技巧
查看>>
在WPF中调用Winform控件
查看>>
matlab产生正态分布样本
查看>>
提高myEclipse的开发效率和外观,这些你都设置了吗?
查看>>
poj2777
查看>>
idea 根据数据库表自动创建持久化类
查看>>
sock文件
查看>>
php dom 分离html内容
查看>>
Angular.js 简单实现数字变汉字
查看>>
AngularJS 控制器 ng-controller
查看>>
sony笔试
查看>>
一、HTML和CSS基础--HTML+CSS基础课程--第2部分
查看>>
hdu1527取石子游戏---(威佐夫博弈)
查看>>
Python path
查看>>
Kruskal算法
查看>>
父子类中静态方法和属性实现
查看>>
hdu3081 Marriage Match II
查看>>
Oracle表空间
查看>>
Linux下如何实现对某个文件夹进行压缩
查看>>
SonarQube规则之坏味道类型
查看>>