list排序的问题

现象:
list如何按照自定义排序

方法:
一:list有序列表 输出按照放入先后排序
list排序的问题_第1张图片

二:使用Collections.sort()排序
list排序的问题_第2张图片

三:创建对象
list排序的问题_第3张图片

四:
list排序的问题_第4张图片
发现,代码直接报错了:

Bound mismatch: The generic method sort(List) of type Collections is not applicable for the arguments (List). The inferred type Person is not a valid substitute for the bounded 
parameter >

从上面可知,Person不是一个有效的参数类型,而应该extends Comparable。
要排序需要有排序的规则,要有比较。Inteage这个对象已经帮我们实现了Comparable接口,所以Inteage类型自己就是可以比较的。而我们的Student如果想要排序,也必须能够按某种规则进行比较,也就是要实现一个比较器。我们可以通过实现Comparable或Comparator接口实现比较器 。

Interage实现了接口
这里写图片描述

五:Comparable实现排序 :实体类Student需要implements Comparable,然后重写compareTo方法,在此方法里实现比较规则
list排序的问题_第5张图片
list排序的问题_第6张图片
实现接口重写方法之后实现排序
list排序的问题_第7张图片

六:Comparator实现排序:Comparator实现比较器,是定义在Person类的外部的,因此实体类Person不需要做任何变化
list排序的问题_第8张图片
list排序的问题_第9张图片
排序输出:
list排序的问题_第10张图片
七:使用内部类重新方法来实现通过对象某个参数来排序
stockChangeDetails 是需要排序的list ,通过重写compare的方法来自定义排序:方法返回-1 就会调换o1和o2的循序 返回0或者1 则不会改变
list排序的问题_第11张图片

你可能感兴趣的