文章目录
问题:
如果数组中存储的是自定义对象,怎么用Arrays类进行排序?
简化代码
简化前
写代码的时候是没有异常的,但是运行时异常。因为Java不知道用什么规则去比较自定义类对象。
解决方法
实现接口然后重写方法 或者 使用匿名内部类,再自己制定比较规则
方法一:该类实现Comparable接口,重写compareTo()方法
让该类的对象实现Comparable(比较规则)接口,然后重写compareTo()方法,自己制定比较规则
Arrays的sort方法是怎么调重写的CompareTo方法的?
不用知道怎么调的,会用就行
Arrays.sort 方法通过调用自定义类中重写的 compareTo 方法来实现排序,开发者只需在自定义类中实现 Comparable 接口并定义比较逻辑即可
方法二:使用sort方法创建匿名内部类
使用sort()方法,创建Comparator比较器接口的匿名内部类对象,然后自己制定比较规则
简写
为什么不直接renturn 身高差
这里没有直接用身高差是因为是得出的结果是double类型,但是要求的返回值是int类型。强转会出现精度丢失。所以我们使用Double类提供的compare方法,传进两个参数。正着传是升序,参数位置倒着是逆序
优先级
近者优先,匿名内部类优先