自然排序


  1. 像String 这样的包装类实现了Comparable接口,重写了compareTo()方法给出了比较两个对象大小的方式。可以直接调用sort方法进行排序。如果想排序自定义的类就需要自己重写compareTo()方法。
  2. 自定义排序时候的规则是小的返回负数,大的返回正数,相等的返回0。

String[] arr = new String[]{"AA","BB","DD","CC","ZZ","GG"};
//数组排序
System.out.println("Arrays.sort(arr)");

因为String重写了Comparable接口中的方法。

Comparable自然排序与Comparator定制排序_自定义排序

以上是根据商品的价钱进行排序的,如果是多种条件进行排序只需要将排序之后的结果在进行二次排序就可以了。

Comparable自然排序与Comparator定制排序_java_02

定制排序

更改jdk中提供的方法, Comparable自然排序与Comparator定制排序_二次排序_03

Arrays.sort()方法是按照字符串从小到大进行排序,这时候还要使用sort方法,但是又不能更改sort方法,于是就可以实现Comparator()接口,重写compare方法。

Comparable自然排序与Comparator定制排序_二次排序_04

Comparable 接口和Comparator 接口的使用对比。

Comparable接口的方式一旦一定,保证Comparable接口实现类的对象在任何地方都可以比较大小,但是Comparator 接口属于临时性的比较大小。