我是Finagle的新手.我现在正在阅读某人的代码,发现Future对象在不同的连接操作中被重用.我的问题是会导致Future对象多次执行(在每个连接中),还是只执行一次并存储结果以供以后连接?
例:
Future a= b
.join(c)
.flatMap(new SomeFunctionReturningA());
Future> future1 = a.join(b);
Future future2 = future1.flatMap(new SomeFunctionReturningD());
future2.get();
那么b会被执行两次,还是只执行一次?
解决方法:
Future是一个值的容器,值只设置一次!
未来[T]有不同的状态:
>空
>使用类型T设置值
>设置为例外
当你在Future A上使用带有函数f的map / flatMap时,你将只创建一个新的Future B,它将是由函数f转换的前一个的结果.
注意:
>如果未来A尚未“填补”,您将获得一个尚未填充的B
>在A中设置值a的线程也将执行f(a)并将值设置为B.
>如果A已经“填充”,那么map / flatMap的调用者也将执行f(a),但它不会重新计算A的值.
>您还可以使用onSuccess / onFailure,它只会注册一些代码,以便在将来获得其值时执行.
标签:java,twitter,future,finagle
来源: https://codeday.me/bug/20190613/1231361.html