1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > Java中的list集合排序方法

Java中的list集合排序方法

时间:2020-07-19 14:01:54

相关推荐

Java中的list集合排序方法

java中提供了对集合进行操作的工具类Collections,

Collections对集合中的元素提供了默认的排序方法,sort(),根据元素的自然顺序对指定列表按升序进行排序。

这里举两个例子来说明下这个方法

1.首先是一个简单的例子

import java.util.ArrayList;import java.util.Collections;import java.util.List;public class Test_02 {public static void main(String[] args) {//创建List<Integer> list = new ArrayList<Integer>();list.add(3);list.add(2);list.add(5);list.add(7);System.out.println(list);//排序Collections.sort(list);System.out.println(list);}}

输出结果:

[3, 2, 5, 7]

[2, 3, 5, 7]

对于这个例子,Integer类自己实现好了Comparable接口,并且重写了comepareTo方法,所以我们可以直接调用方法就可以实现排序,那么有些人可能会有些疑问,下面的例子可能会解决你的这些问题。

2.对于一些,自己创建的类,比如Person类,想根据里面的年龄属性进行排序的话,那么就需要实现Comparable接口,并且重写compareTo方法,这样就可以根据自己的需要,调用sort方法去排序啦,代码附下

public class Person implements Comparable<Person> {private String name;private int age;public String getName() {return name;}public void setName(String name) {this.name = name;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}public Person() {}public Person(String name,int age) {this.name = name;this.age = age;}@Overridepublic int compareTo(Person p) {if(age > p.getAge()) {return 1;}else if(age == p.getAge()) {return 0;}return -1;}@Overridepublic String toString() {return "Person [name=" + name + ", age=" + age + "]";}}

import java.util.ArrayList;import java.util.Collections;import java.util.List;public class Test_01 {public static void main(String[] args) {List<Person> list = new ArrayList<Person>();list.add(new Person("张三",22));list.add(new Person("李四",19));list.add(new Person("王五",23));list.add(new Person("赵六",18));System.out.println(list);Collections.sort(list);System.out.println(list);}}

输出结果:

[Person [name=张三, age=22], Person [name=李四, age=19], Person [name=王五, age=23], Person [name=赵六, age=18]]

[Person [name=赵六, age=18], Person [name=李四, age=19], Person [name=张三, age=22], Person [name=王五, age=23]]

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。