如果一个集合元素是可比较的(实现了Comparable接口),那么就具有了默认排序方法,比较器则是强行改变它默认的比较方式来进行排序。或者有的集合元素不可比较(没有实现Comparable接口),则可用比较器来实现动态的排序。
比较Java中的对象:只能使用== 或 != ;不能使用 > 或 < 。
实际情况中需要对多个对象进行排序,需要比较对象的大小。
如何实现?使用两个接口中的任何一个:Comparable 或 Comparator
自然排序:使用Comparable接口(java. lang.Comparable)
1.像String、包装类等默认实现了Comparable接口,通过重写compareTo(obj)方法,对两个对象大小进行比较;并进行了从小到大的排序。
2. 两个对象即通过重写 compareTo (Object obj)方法,并根据该方法的返回值来比较大小:
如果当前对象this大于形参对象obj,则返回正整数,
如果当前对象this小于形参对象obj,则返回负整数,
如果当前对象this等于形参对象obj,则返回零。
3. 实现 Comparable 接口的对象数组可以通过 Collections.sort 或Arrays.sort 进行自动排序。实现此接口的对象可以用作有序映射中的键或有序集合中的元素,无需指定比较器。
4. 对于自定义类来说,如果需要排序,我们可以让自定义类实现Comparable接口,重写compareTo(obj)方法。在comp