[英]Java 8 lambda predicate chaining?
我无法编译它,甚至可以链接谓词lambdas?
Arrays.asList("1","2","3").stream().filter( (e -> e=="1" ).or(e-> e=="2") ).count();
或者唯一的方法是显式创建一个谓词,然后像这样组合:
Predicate<String> isOne= e -> e=="1";
Arrays.asList("1","2","3").stream().filter( isOne.or(e -> e=="2") ).count();
或者是否有更多“功能优雅”的方式来实现同样的目标?
你可以使用:
((Predicate<String>) e -> e.equals("1")).or(e -> e.equals("2"))
但它不是很优雅。 如果您在线指定条件,只需使用一个lambda:
e -> e.equals("1") || e.equals("2")
我正在研究类似的谓词链接问题,并提出了以下建议
public static <T> Predicate<T> chain (Function<T,Predicate<T>> mapFn, T[]args) {
return Arrays.asList(args)
.stream()
.map(x->mapFn.apply(x))
.reduce(p->false, Predicate::or);
}
链的第一个参数是lambda(Function),它返回一个lambda(Predicate),因此它需要几个箭头
public static void yourExample() {
String[] filterVals = { "1", "2" };
Arrays.asList("1","2","3")
.stream()
.filter(chain(x-> (y-> y.equals(x)), filterVals))
.count();
}
为了比较,这是我想要实现的......
public static void myExample() {
String[] suffixes = { ".png", ".bmp" };
Predicate<String> p = chain (x-> y-> y.endsWith(x), suffixes);
File[] graphics = new File("D:/TEMP").listFiles((dir,name)->p.test(name));
Arrays.asList(graphics).forEach(System.out::println);
}
你可以使用魔术方法$:
<T> Predicate<T> $(Predicate<T> p) {
return p;
}
Arrays.asList("1", "2", "3").stream().filter( $(e -> e=="1").or(e -> e=="2") ).count();
这只是@Chris Jester-Young答案的一小部分。 通过使用方法引用可以缩短表达式:
((Predicate<String>) "1"::equals).or("2"::equals)
Arrays.asList("1","2","3").stream().filter( Arrays.asList("1", "2")::contains).count();
是的方法“要么”是好主意
public static void main(String[] args) {
long count = Arrays.asList("1","2","3").stream().filter(either("1"::equals).or("2"::equals)).count();
System.out.println(count);
}
private static <T> Predicate<T> either(Predicate<T> predicate) {
return predicate;
}
或者你可以使用import static java.util.function.Predicate.isEqual;
并写入isEqual("1").or(isEqual("2"))
Predicate<String> pred1 = "1"::equals;
Predicate<String> pred2 = "2"::equals;
public void tester(){
Arrays.asList("1","2","3").stream().filter(pred1.or(pred2)).count();
}
您可以将您的条件单独移动,以便能够以其他方式重新组合它们。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.