当前位置:首页 > 开发 > 编程语言 > 编程 > 正文

BeanComparator实现ArrayList中的元素按多个属性复合排序

发表于: 2008-08-20   作者:dongwei_6688   来源:转载   浏览次数:
摘要: import java.util.Collections; import java.util.Comparator; import java.util.ArrayList; import org.apache.commons.beanutils.BeanComparator; import org.apache.commons.collections.Compara
import java.util.Collections;    
import java.util.Comparator;    
import java.util.ArrayList;    
import org.apache.commons.beanutils.BeanComparator;    
import org.apache.commons.collections.ComparatorUtils;    
import org.apache.commons.collections.comparators.ComparableComparator;    
import org.apache.commons.collections.comparators.ComparatorChain;    

public class CompareTipA  {    
    private int  id;    
    private String  name;    
    private String age;    

    @SuppressWarnings("unchecked")
    public static void main(String []args) {    

        //在列表中加入若干CompareTipA对象
        ArrayList<Object> list = new ArrayList<Object>();    
        list.add(new CompareTipA(1,"3","五"));    
        list.add(new CompareTipA(1,"1","六"));    
        list.add(new CompareTipA(1,"5","二"));    
        list.add(new CompareTipA(1,"4","四"));    
        list.add(new CompareTipA(4,"2","一"));    

        //创建一个排序规则
        Comparator mycmp = ComparableComparator.getInstance();    
        mycmp = ComparatorUtils.nullLowComparator(mycmp);  //允许null       
        mycmp = ComparatorUtils.reversedComparator(mycmp); //逆序       

        //声明要排序的对象的属性,并指明所使用的排序规则,如果不指明,则用默认排序
        ArrayList<Object> sortFields = new ArrayList<Object>();    
        sortFields.add(new BeanComparator("id", mycmp)); //id逆序  (主)    
        sortFields.add(new BeanComparator("name"));      //name正序 (副) 

        //创建一个排序链
        ComparatorChain multiSort = new ComparatorChain(sortFields); 

        //开始真正的排序,按照先主,后副的规则
        Collections.sort(list,multiSort);    

        for (int i =0;i<list.size();i++) {    
            System.out.println(list.get(i));    //输出    
        }    
        /**
         * 输出结果如下:
         * [id=4,name=2,age=一]
         * [id=1,name=1,age=六]
         * [id=1,name=3,age=五]
         * [id=1,name=4,age=四]
         * [id=1,name=5,age=二]
         */
    }    

    public CompareTipA(int id, String name,String age) {    
        this.id = id;    
        this.name = name;    
        this.age = age;    
    }    

    public int getId() {    
        return this.id;    
    }    

    public void setId(int id) {    
        this.id = id;    
    }    

    public String getName() {    
        return this.name;    
    }    

    public void setName(String name) {    
        this.name = name;    
    }    

//    public int compareTo(Object o) {    
//        return this.comparator.compare(this, o);    
//    }    

    public String toString() {    
        return "[id=" + this.id + ",name=" + this.name +",age=" + this.age +"]";    
    }    

    public String getAge() {    
        return age;    
    }    

    public void setAge(String age) {    
        this.age = age;    
    }    
}

 

——怎么样,很爽吧????

BeanComparator实现ArrayList中的元素按多个属性复合排序

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
Magento的属性可以用来放在产品列表页给产品进行排序,要用来排序的属性只需要在后台属性管理的地方
  首先介绍一下什么是ol元素。这里直接引用MDN里面的定义:The HTML <ol> Element (or HTML
前段时间做个小项目需要查询结果按日期排序并将显示结果每天数据之间用明显的分割线隔开 效果如下:
前段时间做个小项目需要查询结果按日期排序并将显示结果每天数据之间用明显的分割线隔开 效果如下:
此处介绍的情境是: (1)使用table布局ListView。 (2)ListView的数据源是List<T>。 (3)
DROP TABLE IF EXISTS `tempTb`; CREATE TEMPORARY TABLE tempTb SELECT product_id,project_id,COU
近最研究元素排序,稍微总结一下,以后继承补充: 近最决议天每学点数据结构与算法,写客博来促督自
1.Student的Bean如下: public class Student { private int age; private String name; private Str
今天为了解决这个问题耗费了几个小时,现在记录下来,供大家参考。肯定有更好的方法,望不吝赐教!
今天用order by排序 后面跟了多个字段,如sql语句: SELECT a.id,a.loginname,a.address,u.id,u.`na
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号