小编Mar*_*YOT的帖子

如何在Scala中提前返回

我现在正在学习Scala.我喜欢做的一件事就是早退.我相信这对每个人来说都更容易阅读,因为我们之前只是删除了无效状态.现在,由于Scala是一种函数式语言,并且我已经读过切割计算是不好的函数式,我想知道是否有一些技巧或函数式编程等同于早期返回.

这是我要编写的代码,完全清楚,这只是一个愚蠢的例子,我不是在寻找我的特殊案例的特殊黑客,而是更多关于如何处理这些问题的一般建议.

if (request.headers.get(session_header).isEmpty) {
  BadRequest(session_not_set)
} else {
  Ok(CartHelper.getCart(session, user))
}
Run Code Online (Sandbox Code Playgroud)

现在,我很想做的是:

if (request.headers.get(session_header).isEmpty) {
  BadRequest(session_not_set)
  return;
}

Ok(CartHelper.getCart(session,user))
Run Code Online (Sandbox Code Playgroud)

如果你对我有任何暗示!

functional-programming scala

6
推荐指数
1
解决办法
5325
查看次数

Java 8 CompletableFuture从声明中返回一个子类型

抱歉这个糟糕的头衔,如果有人有更好的主意,我愿意接受建议.

我正在玩这个CompletableFuture,我偶然发现了一些奇怪的东西.

假设你有两个类:AB哪里B extends A,B也是一个子类型A.

现在,让我们宣布一个CompletableFuture:

CompletableFuture<A> promiseofA = CompletableFuture.supplyAsync(() -> new B());
Run Code Online (Sandbox Code Playgroud)

这是有效的,因为B它的子类型A符合声明CompletableFuture.现在,如果我想添加一个exceptionally步骤,那么我有一个编译异常:

CompletableFuture<A> promiseOfA = CompletableFuture.supplyAsync(() -> new B())
                                                   .exceptionally(ex -> new B());
Run Code Online (Sandbox Code Playgroud)

在这种情况下,Java正在抱怨,说:

Compilation error[ java.util.concurrent.CompletableFuture<B> cannot be converted to java.util.concurrent.CompletableFuture<A>]
Run Code Online (Sandbox Code Playgroud)

为什么没有这个excepionally步骤而没有它呢?

java completable-future

2
推荐指数
1
解决办法
182
查看次数