大佬教程收集整理的这篇文章主要介绍了使用 completablefuture 以异步方式重写 loop-with-break 逻辑,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我在纯 Java 中有这样的逻辑,我想用异步代码重写:
for (Batch batch : batches) {
int required = N;
for (Item item : batch.items()) {
Response response = clIEnt.syncrequest(new request(item));
int score = score(responsE);
required -= score;
if (required < 0) {
break;
}
}
}
我需要收集 N 个分数,因此我正在阻止请求,直到达到分数。 如果我替换
Response response = clIEnt.asyncrequest(new request(item));
类似的东西
CompletableFuture<Response> responseFuture = clIEnt.asyncrequest(new request(item));
responseFuture.whenCompleted((response,exception) -> {...});
这意味着将提交对所有项目的请求(如果我需要,例如只有 5 个才能达到分数)。 是否有一些最佳实践如何以异步方式做到这一点?我有一个想法,添加一些可变计数器,当完成时会增加,如
CompletableFuture<Response> responseFuture = CompletableFuture.supplyAsync(() -> {
if (notEnoughscore(counter) {
return clIEnt.asyncrequest(new request(item));
} else {
CompletableFuture.completedFuture(null);
}
});
但在这种情况下,据我所知,可能会触发不必要的客户端请求。
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)
以上是大佬教程为你收集整理的使用 completablefuture 以异步方式重写 loop-with-break 逻辑全部内容,希望文章能够帮你解决使用 completablefuture 以异步方式重写 loop-with-break 逻辑所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。