1、原则
comparator接口可以实现自定义排序,实现comparator接口时,要重写compare方法:
int compare(object o1, object o2) 返回一个基本类型的整型
如果要按照升序排序,则o1 小于o2,返回-1(负数),相等返回0,01大于02返回1(正数)
如果要按照降序排序,则o1 小于o2,返回1(正数),相等返回0,01大于02返回-1(负数)
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
|
import java.util.arraylist; import java.util.comparator; import java.util.list; public class usercomparator implements comparator < user > { public static void main( string[] args ) { list < user > users = new arraylist < user >(); users.add( new user( 10 , "a" ) ); users.add( new user( 11 , "d" ) ); users.add( new user( 15 , "s" ) ); users.add( new user( 6 , "x" ) ); users.add( new user( 17 , "a" ) ); users.add( new user( 17 , "b" ) ); users.add( new user( 17 , "c" ) ); users.add( new user( 17 , "d" ) ); usercomparator comparator = new usercomparator(); users.sort( comparator ); // 也可以使用:collections.sort( users, comparator ); for ( user u : users ) { system.out.println( u ); } } @override public int compare( user u1, user u2 ) { if ( u1.equals( u2 ) ) { return 0 ; } else if ( u1.getage() < u2.getage() ) { return 1 ; } else if ( u1.getage() == u2.getage() ) { int f = u1.getname().compareto( u2.getname() ); if ( f < 0 ) { return - 1 ; } return 0 ; } else { return - 1 ; } } } class user { private int age; private string name; public user() { } public user( int age, string name ) { this .age = age; this .name = name; } 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; } @override public string tostring() { return "user [age=" + age + ", name=" + name + "]" ; } } |
1
2
3
4
5
6
7
8
|
user [age= 17 , name=a] user [age= 17 , name=b] user [age= 17 , name=c] user [age= 17 , name=d] user [age= 15 , name=s] user [age= 11 , name=d] user [age= 10 , name=a] user [age= 6 , name=x] |
以上所述是小编给大家介绍的java使用comparator接口实现自定义排序详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:https://www.cnblogs.com/mengzj233/p/9816289.html