首页 > Java > java教程 > 正文

集合(放对象)排序

巴扎黑
发布: 2016-12-10 09:22:00
原创
1992人浏览过

用collections.sort方法对list排序有两种方法 
第一种是list中的对象实现comparable接口,如下: 
[java] view plain copy 
/** 
* 根据order对user排序 
*/  
public class user implements comparable<user>{  
     private string name;  
     private integer order;  
     public string getname() {  
         return name;  
     }  
     public void setname(string name) {  
         this.name = name;  
     }  
     public integer getorder() {  
         return order;  
     }  
     public void setorder(integer order) {  
         this.order = order;  
     }  
     public int compareto(user arg0) {  
         return this.getorder().compareto(arg0.getorder());  
     }  
} 测试一下:  
public class test{  
  
     public static void main(string[] args) {  
         user user1 = new user();  
         user1.setname("a");  
         user1.setorder(1);  
         user user2 = new user();  
         user2.setname("b");  
         user2.setorder(2);  
         list<user> list = new arraylist<user>();  
         //此处add user2再add user1  
         list.add(user2);  
         list.add(user1);  
         collections.sort(list);  
         for(user u : list){  
             system.out.println(u.getname());  
         }  
     }  
}   



输出结果如下 


第二种方法是根据collections.sort重载方法来实现,例如: 
[java] view plain copy 
/** 
* 根据order对user排序 
*/  
public class user { //此处无需实现comparable接口  
    private string name;  
     private integer order;  
     public string getname() {  
         return name;  
     }  
     public void setname(string name) {  
         this.name = name;  
     }  
     public integer getorder() {  
         return order;  
     }  
     public void setorder(integer order) {  
         this.order = order;  
     }  
}  
  
主类中这样写即可(hastset——>list——>sort进行排序):  
public class test {  
    public static void main(string[] args) {  
        user user1 = new user();  
        user1.setname("a");  
        user1.setprice(11);  
        user user2 = new user();  
        user2.setname("b");  
        user2.setprice(2);  
  
        set<user> hset = new hashset<user>();  
        hset.add(user2);  
        hset.add(user1);  
  
        list<user> list = new arraylist<user>();  
        list.addall(hset);  
  
  
        collections.sort(list,new comparator<user>(){  
            public int compare(user arg0, user arg1) {  
                return arg0.getprice().compareto(arg1.getprice());  
            }  
        });  
        for(user u : list){  
            system.out.println(u.getname());  
        }  
    }  


输出结果如下: 



默认为升序,将。return arg0.getorder().compareto(arg1.getorder());    改为: 
return arg1.getorder().compareto(arg0.getorder());   
就成降序的了。 

简篇AI排版
简篇AI排版

AI排版工具,上传图文素材,秒出专业效果!

简篇AI排版 554
查看详情 简篇AI排版
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号