Java中的2种集合排序方法介绍
直接上代码:
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
/**
*
*
* ClassName CollectionsSort
*
*
* Description 主要介绍两种集合的排序算法
* 第一:java.util.Collections.sort(java.util.List),要求所排序元素必须实现java.lang.Comparable接口
* 第二:java.util.Collections.sort(java.util.List, java.util.Comparator),这个方法要求实现java.util.Comparator接口
* 第三:下面的例子使用的是对int型属性排序,对String属性排序可以使用以下方法
* public int compareTo(Cat o){return this.getName().compareTo(o.getName(0);}
* 第四:compareTo()函数的说明
* 如果 结果;
* <0 a=
* ==0 a==b;
* >=0 a>b;
*
*
* @author wangxu wangx89@126.com
*
* Date 2014-9-16 下午04:52:57
*
* @version V1.0
*
*/
public class CollectionsSort {
public static void main(String[] args) {
// method1();测试第一个方法
method2();// 测试第二个方法
}
public static void method1() {
List list = new ArrayList();
Cat c = new Cat("a", 10);
list.add(c);
c = new Cat("b", 20);
list.add(c);
c = new Cat("c", 3);
list.add(c);
// 升序排列输出
Collections.sort(list);
System.out.println(list);
// 降序排列输出
Collections.sort(list, Collections.reverseOrder());
System.out.println(list);
}
public static void method2() {
List list = new ArrayList();
Cat c = new Cat("a", 10);
list.add(c);
c = new Cat("b", 20);
list.add(c);
c = new Cat("c", 3);
list.add(c);
Comparator catComparator = new Cat();
// 升序排列输出
Collections.sort(list, catComparator);
System.out.println(list);
// 降序排列输出
catComparator = Collections.reverseOrder(catComparator);
Collections.sort(list, catComparator);
System.out.println(list);
}
}
class Cat implements Comparable, Comparator {
private int age;
private String name;
public Cat() {
}
public Cat(String name, int age) {
this.age = age;
this.name = name;
}
public int getAge() {
return this.age;
}
public String getName() {
return this.name;
}
public void setAge(int age) {
this.age = age;
}
public void setName(String name) {
this.name = name;
}
// 实现了Comparable接口,不要重写该方法
@Override
public int compareTo(Cat o) {
// TODO Auto-generated method stub
return this.age - o.age;
}
@Override
public String toString() {
// TODO Auto-generated method stub
return "名字:" + getName() + ",年龄:" + getAge();
}
// 实现了Comparator接口,需要重写该方法
@Override
public int compare(Cat o1, Cat o2) {
// TODO Auto-generated method stub
return o1.getAge() - o2.getAge();
}
}
相关阅读:
ASP.NET中 script runat server 的用法
Win10下SSD固态硬盘怎么开启TRIM?
ie浏览器使用js导出网页到excel并打印
Win10 10525/10527可以免费试用多长时间? 2016年7月15日截止
自己动手打造ajax图片上传(网上没有的)
XP系统经常会出现盗版提示怎么办? XP系统关闭盗版提示的设置方法
Win10中IE浏览器无法打开网页上网的两种解决办法
JSON字符串和对象相互转换实例分析
android压力测试命令monkey详解
C语言简单实现计算字符个数的方法
用C语言判断一个二叉树是否为另一个的子结构
CSS定义Radio单选项和Checkbox复选框样式有效代码
ASP.NET过滤HTML字符串方法总结
苹果Mac10.9系统使用CleanMyMac后lunchpad图标丢失的原因及解决方法介绍