Comparable接口的用法与排序算法的脱藕

2008-02-23 09:13:37来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

在写程序的时候经常会遇到排序的需求,而且这些个客户有时会想女人一样多变。所以将排序算法与业务逻辑脱藕是非常明智的选择。程序员用代码说话,下面是一个例子:(注意该例子抽象的不是很好,仅做脱藕演示之用)

import Java.util.ArrayList;
import java.util.Collections;
import java.util.List;

/**
* 注意:此类具有与 equals 不一致的自然排序(这句话的含义参见JDK)
*/
public class Person implements Comparable {

private int age;

public int compareTo(Object person) {
return this.age - ((Person) person).getAge();
}

public int getAge() {
return age;
}

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

public String toString() {
return String.valueOf(this.age);
}

public static void main(String[] args) {
List persons = new ArrayList();
for (int i = 0; i < 10; i ) {
Person person = new Person();
person.setAge(30 - i);
persons.add(person);
}
// 注释下面一行看看
Collections.sort(persons);//调用过这个方法后,persons里的元素将按由小到大排列

for (int i = 0; i < persons.size(); i ) {
System.out.println(persons.get(i));
}
}

}
其实,一个好的系统会面临很多很多排序要求所以仅仅Comparable接口是非常不够用的。这时就要用到Comparator接口,也就是大名鼎鼎的“比较器”。有空再把这个的例子写一个出来

上一篇: javascript如何调用C#后代码中的过程 和ASP.NET调用JS乱码解决方案
下一篇: 使用JasperReports合并多个报表的word文档问题解决方法

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:从Python

下一篇:Java路径问题最终解决方案—可定位所有资源的相对路径寻址