Comparable排序
来源:互联网 发布:涉及大数据的上市公司 编辑:程序博客网 时间:2024/06/09 14:09
如果想使用排序,那么就一定离不开Comparable 接口。 它是一个简单接口,仅有一个方法compareTo(
public interface java.lang.Comparable {
public int compareTo(Object o);
}
下面是一个简单的例子:
package com.discursive.jccook.collections.compare;
import java.util.*;
import org.apache.commons.lang.StringUtils;
import org.apache.commons.collections.comparators.ReverseComparator;
public class BookComparator implements Comparator {
public int compare(Object o1, Object o2) {
int comparison = -1;
if( o1 instanceof Book && o2 instanceof Book ) {
Book b1 = (Book) o1;
Book b2 = (Book) o2;
String b1Name = b1.getName( );
String b2Name = b2.getName( );
String b1Author = b1.getAuthor( );
String b2Author = b2.getAuthor( );
if( StringUtils.isNotEmpty( b1Name ) &&
StringUtils.isNotEmpty( b2Name ) ) {
comparison = b1Name.compareTo( b2Name );
}
if( comparison == 0 &&StringUtils.isNotEmpty( b1Author ) && StringUtils.isNotEmpty( b2Author ) ) {
comparison = b1Author.compareTo( b2Author );
}
}
return comparison;
}
}
还有一种情况是,使用BeanComparator 对 bean 进行单个属性的排序 ,BeanComparator 是 BeanUtils API 中的一个类,
要求这个bean有这个属性,而且有 get 和 set 方法.
如果找不到该Bean的相对的属性,则会抛出 ClassCastException
例如,"name" 属性来对集合中的 bean 进行排序而建立的实例
private BeanComparator comparator = new BeanComparator("name");
- Comparable排序
- 利用Comparable进行排序
- 集合排序 Comparator Comparable
- 对象排序:Comparator&Comparable
- Comparable排序(备忘)
- 集合排序 Comparator Comparable
- Comparable实现对象排序
- Comparator和Comparable排序
- 字符串、list 排序 comparable
- Comparable接口排序
- Comparable(自然排序)
- Comparable实现自定义排序
- Java中的排序 Comparator,Comparable
- 对象排序:Comparator&Comparable
- java comparable 和 comparator 排序
- Comparable接口实现对象排序
- Java Comparable 解决排序问题
- 接口Comparable实现List排序
- MySQL语法语句大全
- 园与线的拖动02
- Java初学者都必须理解的六大问题(转载)
- 。net的基础概念
- UBB解析优化的心得:Regex构造函数的性能
- Comparable排序
- "Illegal group reference"异常的分析
- C#3.0 automatic properties
- Series 60 3rd上绘图时设置字体的大小
- 生命的价值
- Asp.Net常见问题及技术实现方案(一)
- 何去何从-------------大家给个建议吧
- WebService介绍(一):创建WebService
- 无题