
本文旨在解决如何基于已有的 Comparator<Integer> 创建用于比较自定义类型 IntIdx 的 Comparator<IntIdx>。通过使用 Comparator.comparing(Function, Comparator) 方法,可以优雅地将外部传入的比较器应用于 IntIdx 对象的特定属性,并与其他比较规则组合,从而实现灵活的排序逻辑。
在Java中,Comparator 接口用于定义对象的排序规则。当我们需要对自定义类型进行排序,并且排序规则的一部分需要根据外部传入的 Comparator 来动态调整时,就需要一种方法将外部 Comparator 应用于自定义类型的特定属性。本文将介绍如何使用 Comparator.comparing(Function, Comparator) 方法来实现这一目标。
假设我们有以下 IntIdx 类:
private static class IntIdx {
int val;
int idx;
IntIdx(int val, int idx) {
this.val = val;
this.idx = idx;
}
public int getValue() {
return val;
}
public int getIdx() {
return idx;
}
}现在,我们希望创建一个 Comparator<IntIdx>,它首先使用外部传入的 Comparator<Integer> 比较 IntIdx 对象的 val 属性,然后使用自然顺序比较 idx 属性。
使用 Comparator.comparing(Function, Comparator)
Comparator.comparing(Function, Comparator) 方法接受两个参数:
以下代码展示了如何使用该方法创建 Comparator<IntIdx>:
import java.util.Comparator;
import java.util.List;
import java.util.ArrayList;
public class ComparatorExample {
private static class IntIdx {
int val;
int idx;
IntIdx(int val, int idx) {
this.val = val;
this.idx = idx;
}
public int getValue() {
return val;
}
public int getIdx() {
return idx;
}
@Override
public String toString() {
return "(" + val + ", " + idx + ")";
}
}
static public List<Integer> decode(List<Integer> al, Comparator<Integer> valComp) {
final Comparator<IntIdx> idxComp = Comparator
.comparing(IntIdx::getValue, valComp)
.thenComparingInt(IntIdx::getIdx);
// 示例:使用 Comparator 对 IntIdx 列表进行排序
List<IntIdx> intIdxList = new ArrayList<>();
intIdxList.add(new IntIdx(3, 2));
intIdxList.add(new IntIdx(1, 1));
intIdxList.add(new IntIdx(3, 1));
intIdxList.add(new IntIdx(1, 2));
intIdxList.sort(idxComp);
System.out.println("Sorted list: " + intIdxList);
return null; // 仅仅为了满足方法签名,实际应用中应返回有意义的值
}
public static void main(String[] args) {
// 创建一个逆序的 Integer 比较器
Comparator<Integer> reverseIntegerComparator = Comparator.reverseOrder();
// 创建一个示例 Integer 列表
List<Integer> integerList = new ArrayList<>();
integerList.add(1);
integerList.add(2);
integerList.add(3);
// 调用 decode 方法,传入 Integer 列表和逆序比较器
decode(integerList, reverseIntegerComparator);
}
}在上述代码中,Comparator.comparing(IntIdx::getValue, valComp) 创建了一个 Comparator<IntIdx>,它使用 valComp 比较 IntIdx 对象的 getValue() 方法的返回值。然后,thenComparingInt(IntIdx::getIdx) 将 idx 属性的自然顺序比较添加到比较规则中。
注意事项
总结
通过使用 Comparator.comparing(Function, Comparator) 方法,我们可以灵活地将外部传入的 Comparator 应用于自定义类型的特定属性,并与其他比较规则组合,从而实现动态的排序逻辑。这种方法比手动编写多行 lambda 表达式更加简洁和易于维护。
以上就是基于自定义Comparator创建Comparator的教程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号