- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在开发的应用程序中有一个 RecyclerView,我可以用它填充各种项目和搜索/过滤/排序/等等。目前致力于排序。
我有多个可以排序的标准,可以从下拉微调器中选择。数据对象中排序的值包括字符串、整数和枚举,所有这些都非常容易排序。然而,虽然一些排序选项只需要一个标准,但有些需要二级或三级标准(在极少数情况下最多需要 4 个)。为了有效地使用 Collections.sort(List, Comparator)
,我必须编写大量的自定义比较器,所以我希望有一些方法可以避免这种情况。
事实证明,Java 8 有一个很棒的解决方案:Comparator.comparing(...)
,它会为您生成比较器,并且可以通过 Comparator.comparing() 轻松无限地扩展。 thenComparing().thenComparing()...
。它还具有 List myList.sort()
,与 Collections.sort(myList)
相比,我不确定效率如何,但我觉得它更干净。我调查了一下,觉得只是我的运气!一段时间以来,Android 一直在支持许多 Java 8 功能!
不幸的是,Android Studio 告诉我,出于某种原因,Comparator.comparing()
以及 List::sort
仅在 API 24 及更高版本上受支持。这对我来说实际上行不通,因为我正在开发的应用程序“需要”运行低至 API 15-16。然而,我觉得这很奇怪,因为我尝试过其他 Java 8 功能(lambda 表达式,如 (o1, o2) -> (o1.toString().compareTo(o2.toString())
和上面的 List::sort
之类的方法引用)在我检查过的范围内的所有 API 级别上都可以正常工作,只要您指定目标是 Java 8。毕竟这是 Java 8 的东西,不是Android 的东西。
考虑到所有这些,有没有办法让 Comparator.comparing()
和 List::sort
在 API 24 以下工作?我在 Google 搜索中没有找到任何内容,它们最终都指向 Android 的 Java 8“文档”或比较器和列表的 JavaDocs。 Android 支持库之一(似乎不太可能)或第三方库/hack,如 Retrolambda ?
最佳答案
尝试将一些 java 8 功能移植到 java 6/7 的 streamsupport 库: https://github.com/streamsupport
他们有你需要的类(class): https://github.com/streamsupport/streamsupport/blob/master/src/main/java/java8/util/Comparators.java(它从 Comparator
重命名为 Comparators
只是为了避免名称冲突)。
关于java - Android - 是否可以使用 Comparator.comparing 而不是 API < 24 上的自定义比较器对列表进行排序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48648152/
我经常有一个 Comparator 类型,而我需要一个 Comparable 类型,反之亦然。是否有可重用的 JDK API 可以相互转换?类似的东西: public static Comp
我怎么能写这个 Comparator sort = (i1, i2) -> Boolean.compare(i2.isOpen(), i1.isOpen()); 像这样(代码不起作用): Compa
请帮助她。我有一个错误 Collections.sort(var4, new Comparator() { public int compare(TreeMap var1, TreeMa
学习 Kotlin,我试图了解 Java 的 Comparator接口(interface)有效 - 主要是 compare() 函数,这样我就可以利用它。 我已经尝试阅读 compare() 的文档
我有以下程序 List numbers = Arrays.asList("10", "68", "97", "9", "21", "12"); Collections.sort(numbers, (
我想根据嵌套类的属性对如下所示的列表进行排序。 class Test { private NestedClass nestedClass; private AnotherNes
我很好奇“Beyond Compare”的算法是如何工作的? 我猜想他们使用了一种标准的(众所周知的?)算法来实现“字符与字符”的比较。你知道这个算法的名字吗?谢谢 最佳答案 Beyond Compa
这个问题已经有答案了: How does the sort() method of the Collection class call the Comparable's compareTo()? (1
这个问题已经有答案了: 已关闭12 年前。 Possible Duplicates: difference between compare() and compareTo() Java: What i
我被要求为某个类实现Comparable或Compartor,我们称之为V。 假设我有一个 V 的 Collection 或 Set(还不确定,但我认为这并不重要)。 V 有一个方法,可以评估它的“权
我正在查看Java8中实现的Comparator.comparing方法的源代码 这是代码 public static Comparator comparing( Function
假设我有一个类 ClassA,它的属性是 ClassB: public ClassA { private String attr; private ClassB classB; } p
我有一个自定义比较器,其比较逻辑如下: List l = new ArrayList(); l.add("tendercoupon"); l.add("giftcard
我正在努力实现一个处理 Comparator 和 Comparable 接口(interface)的层次结构。我不清楚的几件事: 如果我将比较器添加到比较器链中,这段代码究竟意味着什么 chain.a
正在关注 this question关于按另一个列表对列表进行排序,我尝试做同样的事情 - 但由于某种原因它对我不起作用。我错过了什么? List nums = Arrays.asList(5
假设我有一个像这样的领域模型: class Lecture { Course course; ... // getters } class Course { Teache
在表达式 > 中像这样的签名 public static > foo(T x) { ... } T的描述递归地依赖于Comparable . 如果T延伸Comparable ,和Comparable延
所有“数字”比较器(例如 Comparer.Default 、 Comparer.Default 等)返回 -1 的原因是什么? , 0或 1 ,但是 Comparer.Default和 Compar
(如果这是重复的,请指出正确的答案!我搜索并阅读了几个(> 5)个相关问题,但似乎没有一个是正确的。还查看了泛型常见问题解答和其他来源...) 当一个集合类接受一个比较器时,它应该具有 Compara
SBCL 1.3.1 综上所述,a是一个列表,'(7),b通过setq sbcl This is SBCL 1.3.1.debian, an implementation of ANSI Common
我是一名优秀的程序员,十分优秀!