java的比较器

java的比较器:Comparable和Comparator接口两种 类比较器。在使用时,首先实现接口,
例如:

// 这里的MyTestClass 是测试比较器类对象,<>中的是尸体对象。序列化看需要。
public class MyTestClass implements Comparable<MyTestClass>, Serializable{....}

①Comparable —>Comparable是排序接口
compare(),比较此对象与指定对象的顺序,如果该对象小于、等于或大于指定对象,则分别返回负整数、零或正整数。

②Comparator
Comparator是比较接口,我们如果需要控制某个类的次序,而该类本身不支持排序(即没有实现Comparable接口),那么我们就可以建立一个“该类的比较器”来进行排序,这个“比较器”只需要实现Comparator接口即可;

public class PersonCompartor implements Comparator<Person>

CompareTo()方法: 如果返回值大于0,则将大的数放后面;如果返回值等于0,则不做任何处理; 如果返回值小于0, 则将小的数放前面。也就是说 java默认的排序方式是升序排序
List排序方法 , Collections.sort()和Arrays.sort(),他们的实质都是Array.sort();,用于集合/数组比较

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java,Comparator是一个接口,它定义了一个用于比较个对象的方法compare(Object o1, Object o2)。Comparator接口通常用于对集合的元素进行排序。 Comparator接口的compare方法返回一个int值,表示个对象的相对顺序。如果第一个对象小于第二个对象,则返回负数;如果第一个对象等于第二个对象,则返回0;如果第一个对象大于第二个对象,则返回正数。 Comparator接口的实现类可以使用匿名内部类、Lambda表达式或单独的类来创建。在比较个对象时,可以使用任何属性或方法来定义它们之间的关系。 下面是一个使用Comparator接口对字符串进行排序的例子: ``` List<String> strings = Arrays.asList("apple", "orange", "banana", "pear"); Collections.sort(strings, new Comparator<String>() { public int compare(String s1, String s2) { return s1.compareTo(s2); } }); ``` 这个例子,我们创建了一个字符串列表,并使用Collections.sort方法将其排序。我们使用了一个匿名内部类来实现Comparator接口,将字符串按字典序排序。 在Java比较器的顺序是根据返回值来确定的。如果compare方法返回负数,则第一个对象在第二个对象之前;如果compare方法返回正数,则第一个对象在第二个对象之后;如果compare方法返回0,则个对象相等,它们的相对位置不变。 比较器的实现通常需要考虑到多个因素,例如按照价格排序时可能需要同时考虑产品的名称、品牌、型号等因素。在这种情况下,我们可以使用Java 8引入的多字段排序方法,或者创建一个自定义比较器来实现排序。 总之,Comparator是Java非常重要的一个接口,它提供了一种灵活的方法来对集合的对象进行排序。熟练掌握Comparator接口的使用方法可以让我们更好地处理集合数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值