论坛首页 入门技术论坛

list 排序java代码

浏览 7992 次
该帖已经被评为新手帖
作者 正文
   发表时间:2008-04-24  

常常遇到数组排序的问题.比如我有一个Person类,它的实例对象存储在ArrayList数组中,现在要把ArrayList数组中的Person对象按照年龄排序.
其实这种情况经常遇到.
下面给出源代码:

1:Person.java文件:-------------------------------
public class Person{
String name;
int age;

public Person(String name,int age){
this.name = name;
this.age = age;

}

public int getAge() {
return age;
}

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

public String getName() {
return name;
}

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

}


2:Mycomparator.java-------------------------------
//实现Comparator接口,也就是定义排序规则,你几乎可以定义任何规则
package com.infoearth;
import java.util.*;
public class Mycomparator implements Comparator{

public int compare(Object o1,Object o2) {
Person p1=(Person)o1;
Person p2=(Person)o2;
if(p1.age<p2.age)
  return 1;
else
  return 0;
}

}

3:ListSort.java------------------------------------

package com.infoearth;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;

public class ListSort {
public static void main(String[] args){
ArrayList list = new ArrayList();
list.add(new Person("lcl",28));
list.add(new Person("fx",23));
list.add(new Person("wqx",29));
Comparator comp = new Mycomparator();
Collections.sort(list,comp);
for(int i = 0;i<list.size();i++){
  Person p = (Person)list.get(i);
  System.out.println(p.getName());
}

}

}

   发表时间:2008-04-24  
不明白为什么
没有-1呢?
Comparator应该反回
1,0,-1
0 请登录后投票
   发表时间:2008-04-30  
恩对,返回值是1,0,-1没错,呵呵
我只是做了简单的比较,当返回不是1或0的时候会抛出ClassCastException
这个例子仅是简单的说明自定义排序的实现,具体的项目中当然没这么简单,你要考虑所有的可能,谢谢你的意见,在以后的例子中我会考虑尽量全面些。
3X
0 请登录后投票
   发表时间:2008-06-27  
你的这个不通用,而且是单个属性的,你去看看我写的通用多属性对象排序比较吧
0 请登录后投票
论坛首页 入门技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics