1. Java对Bean排序,可以通过实现Comparator或者Comparable接口
2. Comparator或者Comparable接口可以根据实际的需求来排序,但是如果想用通用的比较方式,可以使用apache的BeanComparator来实现。 具体代码如下
import org.apache.commons.beanutils.BeanComparator;
import org.apache.commons.collections.ComparatorUtils;
import org.apache.commons.collections.comparators.ComparableComparator;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
public class Compare {
/**
*
* @param list 需要排序的类别
* @param fieldName 按照fieldName排序
* @param asc true升序, false降序
* @param <T>
*/
public static <T> void sort(List<T> list, String fieldName, boolean asc) {
Comparator<?> mycmp = ComparableComparator.getInstance();
mycmp = ComparatorUtils.nullLowComparator(mycmp); // 允许null
if (!asc) {
mycmp = ComparatorUtils.reversedComparator(mycmp); // 逆序
}
Collections.sort(list, new BeanComparator(fieldName, mycmp));
}
}
3.Comparator或者Comparable接口实现以后完善
4. 实现Comparable接口要注意满足三个条件:
ComparaTo方法的通用约定与equals方法的通用约定具有相似的特征(自反性,对称性,传递性,非空型)
如果不满足,会报Comparison method violates its general contract! 异常
public class CategoryCompare implements Comparator<Category> {
@Override
public int compare(Category o1, Category o2) {
if(o1.getLevel() > o2.getLevel()){
return 1;
} else {
return -1;
}
}
}
如上代码中,如果两个对象level相同, 不满足自反性 ,应该将level相等的情况考虑进去,修改如下
public class CategoryCompare implements Comparator<Category> {
@Override
public int compare(Category o1, Category o2) {
if(o1.getLevel() > o2.getLevel()){
return 1;
}else if(o1.getLevel() == o2.getLevel()){
if(o1.getId()> o2.getId()){
return -1 ;
}else{
return 1 ;
}
}
else {
return -1;
}
}
}
未完待续