开发中有时候需要自己封装分页排序时,List如何对某一属性排序呢,分享一个小实例,大家共勉,希望能对大家有用,请多多指教。
1.Student的Bean如下:
|
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
|
public
class Student {
privateint
age;
privateString name;
privateString weight;
publicString getWeight() {
returnweight;
}
publicvoid
setWeight(String weight) {
this.weight = weight;
}
publicint
getAge() {
returnage;
}
publicvoid
setAge(intage) {
this.age = age;
}
publicString getName() {
returnname;
}
publicvoid
setName(String name) {
this.name = name;
}
} |
2.按照List中对象的Int类型属性进行排序
|
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
|
/** * 按照List中的某个Int类型的属性进行排序
* @param list
*/
@SuppressWarnings("unchecked")
public
static void sortIntMethod(List list){
Collections.sort(list,new
Comparator(){
@Override
publicint
compare(Object o1, Object o2) {
Student stu1=(Student)o1;
Student stu2=(Student)o2;
if(stu1.getAge()>stu2.getAge()){
return1;
}elseif(stu1.getAge()==stu2.getAge()){
return0;
}else{
return-1;
}
}
});
System.out.println("/////////////排序之后///////////////");
for(inti=0;i<list.size();i++){
Student st=(Student)list.get(i);
System.out.println("st.age="+st.getAge()+",st.name="+st.getName());
}
} |
3.按照List中对象的String类型的属性进行排序
1)方法一:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
/** * 按照List中的某个String类型的属性进行排序
* @param list
*/
@SuppressWarnings("unchecked")
public
static void sortStringMethod(List list){
Collections.sort(list,new
Comparator(){
@Override
publicint
compare(Object o1, Object o2) {
Student stu1=(Student)o1;
Student stu2=(Student)o2;
returnstu1.getName().compareTo(stu2.getName());
}
});
System.out.println("/////////////排序之后///////////////");
for(inti=0;i<list.size();i++){
Student st=(Student)list.get(i);
System.out.println("st.age="+st.getAge()+",st.name="+st.getName());
}
} |
2)方法二:
使用java.text.RuleBasedCollator来实现,用来执行区分语言环境的String 比较:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
/** * 按照List中的某个String类型的属性进行排序
* @param list
*/
@SuppressWarnings("unchecked")
publicstatic
void sortByRuleBasedCollator(List list){
Collections.sort(list,new
Comparator(){
@Override
publicint
compare(Object o1, Object o2) {
return((java.text.RuleBasedCollator)java.text.Collator.getInstance(java.util.Locale.CHINA)).compare(((Student)o1).getName(),
((Student)o2).getName());
}
});
System.out.println("/////////////排序之后///////////////");
for(inti=0;i<list.size();i++){
Student st=(Student)list.get(i);
System.out.println("st.age="+st.getAge()+",st.name="+st.getName());
}
}
|
4.测试排序的方法
|
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
|
@SuppressWarnings("unchecked")
public
static void main(String[] args) {
ArrayList list=newArrayList();
Student t1=newStudent();
t1.setAge(35);
t1.setName("wanglei");
list.add(t1);
Student t2=newStudent();
t2.setAge(4);
t2.setName("lisi");
list.add(t2);
Student t3=newStudent();
t3.setAge(56);
t3.setName("zhonghua");
list.add(t3);
Student t4=newStudent();
t4.setAge(39);
t4.setName("waanglei");
list.add(t4);
System.out.println("/////////////排序之前///////////////");
for(inti=0;i<list.size();i++){
Student st=(Student)list.get(i);
System.out.println("st.age="+st.getAge()+",st.name="+st.getName());
}
//按照List中的某个Int类型的属性进行排序
sortIntMethod(list);
//按照List中的某个String类型的属性进行排序
sortStringMethod(list);
} |
5.结果
还有一种方式是借用于集合的方法
Collections.sort(List<T> list);
此方法排序出来的结果是从小到大 (我测试过整型和时间类型)