服务器之家

服务器之家 > 正文

Java中的2种集合排序方法介绍

时间:2019-12-01 13:03     来源/作者:shijiebei2009

直接上代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
 
/**
 *
 * <p>
 * ClassName CollectionsSort
 * </p>
 * <p>
 * Description 主要介绍两种集合的排序算法<br/>
 * 第一:java.util.Collections.sort(java.util.List),要求所排序元素必须实现java.lang.Comparable接口 <br/>
 * 第二:java.util.Collections.sort(java.util.List, java.util.Comparator),这个方法要求实现java.util.Comparator接口 <br/>
 * 第三:下面的例子使用的是对int型属性排序,对String属性排序可以使用以下方法<br/>
 * public int compareTo(Cat o){return this.getName().compareTo(o.getName(0);}<br/>
 * 第四:compareTo()函数的说明 <br/>
 * 如果 结果;<br/>
 * <0 a<b ;<br/>=
 * ==0 a==b;<br/>
 * >=0 a>b;
 * </p>
 *
 * @author wangxu wangx89@126.com
 *     <p>
 *     Date 2014-9-16 下午04:52:57
 *     </p>
 * @version V1.0
 *
 */
 
public class CollectionsSort {
    public static void main(String[] args) {
        // method1();测试第一个方法
        method2();// 测试第二个方法
    }
 
    public static void method1() {
        List<Cat> list = new ArrayList<Cat>();
        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<Cat> list = new ArrayList<Cat>();
        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<Cat> 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<Cat>, Comparator<Cat> {
    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();
    }
 
}
标签:

相关文章

热门资讯

玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
配置IIS网站web服务器的安全策略配置解决方案
配置IIS网站web服务器的安全策略配置解决方案 2019-05-23
Nginx服务器究竟是怎么执行PHP项目
Nginx服务器究竟是怎么执行PHP项目 2019-05-24
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情 2019-06-22
返回顶部