gpt4 book ai didi

java - 用于表达测试一个 `Predicate` 是否比另一个 `Predicate` 更严格的操作的 API?

转载 作者:行者123 更新时间:2023-11-30 07:01:55 24 4
gpt4 key购买 nike

在 Java 中是否有某种标准方法来表达一个操作来测试一个 Predicate 是否比另一个 Predicate 更严格?

我可以想象类似 pred1.isStricterThan(pred2) 的东西,但是我在 API 中没有看到这样的东西:https://docs.oracle.com/javase/8/docs/api/java/util/function/Predicate.htmlhttps://google.github.io/guava/releases/19.0/api/docs/com/google/common/base/Predicate.html.

这种类型的检查可能有用,例如重新使用缓存的搜索结果。

我看到 isEqual()equals(),这可能会有所帮助,但是还可以进一步优化...

编辑:

示例:

  1. string.contains("xy")string.contains("x")
  2. 更严格
  3. string.contains("xy") && string.contains("ab")string.contains("xy") 更严格
  4. x > 3x > 2 更严格
  5. string.contains("abc") 并不比 string.contains("cd") 更严格

严格性检查方法当然必须根据具体情况巧妙地实现。

编辑2&3:更严格的谓词,当用于过滤时,应该返回不太严格的谓词的子集。

编辑 4:注意:我并不是要求实现。相反,我问是否有一些 API 以标准方式表达这些检查。

最佳答案

您所描述的是graph 。您可以使用Google Guava的新graph API定义谓词严格性图并查询它:

Predicate<String> containsX = string -> string.contains("x");
Predicate<String> containsXy = string -> string.contains("xy");
Predicate<String> containsXyAndAb = string -> string.contains("xy")
&& string.contains("ab");
Predicate<Integer> greaterThan2 = x -> x > 2;
Predicate<Integer> greaterThan3 = x -> x > 3;
Predicate<String> containsAbc = string -> string.contains("abc");
Predicate<String> containsCd = string -> string.contains("cd");

MutableGraph<Predicate<?>> predicateStrictnessGraph = GraphBuilder.directed().build();

predicateStrictnessGraph.addNode(containsX);
predicateStrictnessGraph.addNode(containsXy);
predicateStrictnessGraph.addNode(containsXyAndAb);
predicateStrictnessGraph.addNode(greaterThan3);
predicateStrictnessGraph.addNode(containsAbc);
predicateStrictnessGraph.addNode(containsCd);

predicateStrictnessGraph.putEdge(containsXy, containsX);
predicateStrictnessGraph.putEdge(containsXyAndAb, containsXy);
predicateStrictnessGraph.putEdge(greaterThan3, greaterThan2);

boolean isContainsXyStricterThanContainsX =
Graphs.reachableNodes(predicateStrictnessGraph, containsXy)
.contains(containsX);
// result: true

boolean isContainsXyStricterThanContainsXyAndAb =
Graphs.reachableNodes(predicateStrictnessGraph, containsXy)
.contains(containsXyAndAb);
// result: false

为了进一步说明这一点,请考虑在图表中查询比指定谓词更严格的谓词:

Predicate<String> containsAb = string -> string.contains("ab");
predicateStrictnessGraph.addNode(containsAb);
predicateStrictnessGraph.putEdge(containsAbc, containsAb);
predicateStrictnessGraph.putEdge(containsXyAndAb, containsAb);
Set<Predicate<?>> containsAbAndStricterPredicates =
Graphs.reachableNodes(Graphs.transpose(predicateStrictnessGraph), containsAb);
// result: [containsAb, containsAbc, containsXyAndAb]

更多详情,请参阅 GraphsExplained · google/guava Wiki .

关于java - 用于表达测试一个 `Predicate` 是否比另一个 `Predicate` 更严格的操作的 API?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40776875/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com