ArrayList里的对象按照属性排序

前天被面试问到在集合里的对象按照某个关键字去排序的问题,当时想到了两个解决方案。

  1. 如果结合ORM去考虑,我会在sqlmap里写sql语句的时候用order by去排序,这样查出来获得list就是有序的。不用去排序。
  2. 或则是将对象取出来,然后再单独对对象去排序放到arraylist里去。这种方法麻烦点,但是是最容易想到的解决方案。

今天在朋友建议下参考了API文档,发现原来Collections有静态方法sort去定义对象属性排序,解决方案如下:

//创建一个 User对象
class User
{
    int id;
    String name;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    }
public class SortTest {
    public static void main(String args[])
    {
        //初始化一个list列表
        List<User> list = new ArrayList<User>();
        //初始化20个User对象,id随机
        for(int i = 0;i < 10;i ++)
        {
            User user = new User();
            user.setId((int)(Math.random() * 100));
            user.setName("micro");
            list.add(user);
        }
        //打印出
        for(User user : list)
        {
            System.out.println("User的id:"+user.getId()+" User的name : "+user.getName());
        }
        //按照id去排序
        Collections.sort(list, new Comparator<User>() {

            @Override
            public int compare(User user1, User user2) {
                // TODO Auto-generated method stub
                //定义比较大小
                if(user1.getId() > user2.getId())
                {
                    return 1;
                }
                else if(user1.getId() == user2.getId())
                {
                    return 0;
                }
                else
                {
                    return -1;
                }
            }
        });
        System.out.println("排序结束");
        //排序结束再输出
        for(User user : list)
        {
            System.out.println("User的id:"+user.getId()+" User的name : "+user.getName());
        }
    }
}

运行结果:

User的id:69 User的name : micro
User的id:24 User的name : micro
User的id:87 User的name : micro
User的id:3 User的name : micro
User的id:81 User的name : micro
User的id:8 User的name : micro
User的id:0 User的name : micro
User的id:10 User的name : micro
User的id:82 User的name : micro
User的id:75 User的name : micro
排序结束
User的id:0 User的name : micro
User的id:3 User的name : micro
User的id:8 User的name : micro
User的id:10 User的name : micro
User的id:24 User的name : micro
User的id:69 User的name : micro
User的id:75 User的name : micro
User的id:81 User的name : micro
User的id:82 User的name : micro
User的id:87 User的name : micro

如果降序排序修改为:

Collections.sort(list, new Comparator<User>() {

            @Override
            public int compare(User user1, User user2) {
                // TODO Auto-generated method stub
                //定义比较大小
                if(user1.getId() > user2.getId())
                {
                    return 1;
                }
                else if(user1.getId() == user2.getId())
                {
                    return 0;
                }
                else
                {
                    return -1;
                }
            }
        });

运行结果:

User的id:36 User的name : micro
User的id:80 User的name : micro
User的id:13 User的name : micro
User的id:19 User的name : micro
User的id:31 User的name : micro
User的id:5 User的name : micro
User的id:60 User的name : micro
User的id:26 User的name : micro
User的id:78 User的name : micro
User的id:29 User的name : micro
排序结束
User的id:80 User的name : micro
User的id:78 User的name : micro
User的id:60 User的name : micro
User的id:36 User的name : micro
User的id:31 User的name : micro
User的id:29 User的name : micro
User的id:26 User的name : micro
User的id:19 User的name : micro
User的id:13 User的name : micro
User的id:5 User的name : micro
  • 5
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值