A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 李靖 中级黑马   /  2012-10-29 20:05  /  2149 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

利用Collections工具类可以实现对Arraylist数组排序,代码如下,其中Person类实现了comparable接口
ArrayList<Person> list=new ArrayList<Person>();
  Person person1 =new Person("zhangsan", 14);
  Person person2=new Person("zhangsan", 13);
  list.add(person1);
  list.add(person2);
  Collections.sort(list);
  for (Person person : list) {
   System.out.println(person.getName()+person.getAge());
  }
public class Person implements Comparable{
private String name;
private int age;
Person(String name, int age) {
super();
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public int getAge() {
return age;
}
@Override
public int compareTo(Object o) {
Person person=(Person)o;
int num=this.name.compareTo(person.name);
if(num==0){
  return new Integer(this.age).compareTo(person.age);
}
return num;
}
}

评分

参与人数 1技术分 +1 收起 理由
刘芮铭 + 1

查看全部评分

1 个回复

倒序浏览
本帖最后由 cz2861856 于 2012-10-29 20:23 编辑

通过Collections工具类的sort方法,和比较器Comparator
  1. package day19;
  2. import java.util.*;
  3. public class Test {
  4.         public static void main(String[] args){
  5.                 List<String> list=new ArrayList<String>();
  6.                 list.add("aaaa");
  7.                 list.add("zcv");
  8.                 list.add("dfssdf");
  9.                 list.add("dfgfg");
  10.                 list.add("asdf");
  11.                 Collections.sort(list);             //通过默认排序
  12.                 for(String s:list){                 //遍历输出
  13.                         System.out.println(s);
  14.                 }
  15.                 Collections.sort(list, new StrLenComparator());//按比较器的规则排序
  16.                 for(String s:list){                                            //遍历输出
  17.                         System.out.println(s);
  18.                 }
  19.                
  20.         }
  21. }

  22. class StrLenComparator implements Comparator<String>{//创建一个比较器,按字符长度比较
  23.         public int compare(String s1,String s2){
  24.                 if(s1.length()>s2.length())
  25.                         return 1;
  26.                 if(s1.length()<s2.length())
  27.                         return -1;
  28.                 return s1.compareTo(s2);
  29.         }
  30. }
  31.       
复制代码

评分

参与人数 1技术分 +1 收起 理由
刘芮铭 + 1

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马