我现在正在学习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)
如果你对我有任何暗示!
抱歉这个糟糕的头衔,如果有人有更好的主意,我愿意接受建议.
我正在玩这个CompletableFuture,我偶然发现了一些奇怪的东西.
假设你有两个类:A和B哪里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步骤而没有它呢?