- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我(大部分)理解CompletableFuture的三种执行方式:
我的问题是:什么时候应该赞成使用非异步方法?
如果您有一个代码块调用其他也返回 CompletableFuture
的方法,会发生什么情况?这在表面上看起来可能很便宜,但如果这些方法也使用非异步调用会怎样?这不会加起来成为一个可能变得昂贵的长非异步 block 吗?
是否应该将非异步执行的使用限制在不调用其他方法的简短、定义明确的代码块中?
最佳答案
When should one favor the use of non-async methods?
延续的决定与前面的任务本身没有什么不同。您什么时候选择使操作异步(例如,使用 CompletableFuture
)与编写纯同步代码?同样的指南也适用于此。
如果您只是简单地使用结果或使用完成信号启动另一个 异步操作,那么这本身就是一个廉价操作,没有理由不使用同步完成方法。
另一方面,如果您将多个长时间运行的操作链接在一起,并且每个操作本身都是异步操作,那么请使用异步完成方法。
如果您介于两者之间,请相信您的直觉,或者直接使用异步完成方法。如果您没有协调数以千计的任务,那么您就不会增加大量开销。
Should one restrict the use of non-async execution to short, well-defined code-blocks that do not invoke other methods?
我会将它们用于非长时间运行的操作。您不需要将它们的使用限制在普通 简短的回调中。但我认为您的想法是正确的。
如果您正在使用 CompletableFuture
,那么您已经决定至少一些代码库中的操作需要异步执行,但可能不是所有 em> 操作是异步的。您如何决定哪些应该异步,哪些不应该?如果您将相同的分析应用于延续,我认为您会没事的。
What happens if you have a code block that invokes other methods that also return
CompletableFuture
s? This might look cheap on the surface, but what happens if those methods also use non-async invocation? Doesn't this add up to one long non-async block that could get expensive?
返回 CompletableFuture
通常表示底层操作被安排为异步发生,因此这应该不是问题。在大多数情况下,我希望流程看起来像这样:
CompletableFuture
的异步方法。它安排一些异步操作以最终提供结果。您的调用几乎立即返回,没有阻塞。关于java - 何时使用 CompletableFuture 的非异步方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49649298/
我的应用程序中有 3 种不同的方法。全部返回CompletableFuture .我想并行执行方法 1 和 2。完成方法 1 和 2 后,我想使用方法 1 和 2 返回值的参数触发方法 3。 代码示例
我正在尝试加快对多个 API 的调用。 在下面的代码中,getFilteredEvents是当前同步版本。我有这样的感觉 map(x -> x.getFilteredEvents(eventResea
Q1。我的理解是,如果 future 正常或异常完成,就会调用 completableFuture.handle 。但是超时情况又如何呢? 第二季度。在哪里检查 completableFuture 的
我不明白这里发生了什么 CompletableFuture/supplyAsync。 如果我从先前实例化的 CompletableFuture 对象调用 supplyAsync 方法,它永远不会完成:
我有一个返回 CompletableFuture 的异步方法。 private CompletableFuture asyncA(..) 我公开了一个必须返回 CompleteableFuture 的
我在项目中找到了这段代码: int threadCount = 10; CompletableFuture[] futures = new CompletableFuture[threadCount]
让我们举个例子:我们有四种方法: CompletableFututre loadAndApply(SomeObject someObject); CompletableFuture loadData(
我有一个可完成的 future (future1),它创建了 10 个可完成的 future (futureN)。只有当所有 futureN 都完成时,有没有办法将 future1 设置为完成? 最佳
我想编写一个返回 CompletableFuture 的异步方法. future 的唯一目的是跟踪方法何时完成,而不是其结果。返回CompletableFuture会更好吗?或 Completable
我正在对我的数据库进行多次异步调用。我将所有这些异步调用存储在 List> list 上.我想一起收集所有结果,所以我需要等待所有这些调用完成。 一种方法是创建一个 CompletableFuture
我正在尝试使用 CompletableFuture 链接一些文件处理程序,它应该返回 CompletableFuture : CompletableFuture allGen = loadFile1(
我有 2 个 CompletableFuture。 task2 只能在 task1 完成后启动。然后,我需要等待所有任务完成。在下面的代码中,程序在 task1 结束后结束。 task2 开始但未完成
我有 2 个 CompletableFuture。 task2 只能在 task1 完成后启动。然后,我需要等待所有任务完成。在下面的代码中,程序在 task1 结束后结束。 task2 开始但未完成
我很难弄清楚这一点,并且可以向那些比我更有经验和知识的人寻求帮助。 基本问题是我需要获取对象列表,然后对于返回的每个对象,获取一些详细信息,并将详细信息缝合到对象中。我希望在这方面保持高效;我需要首先
我目前正在使用 CompletableFuture supplyAsync() 方法将一些任务提交到公共(public)线程池。这是代码片段的样子: final List>> completableF
为什么是CompletableFuture.allOf声明为 CompletableFuture而不是返回结果集合或其他东西?我认为制作 CompletableFuture.anyOf 是个好主意返回
我没有看到处理具有异步结果的异常的明显方法。 例如,如果我想重试一个异步操作,我会期待这样的事情: CompletionStage cf = askPong("cause error").handle
比如我有这样的方法: public CompletableFuture getPage(int i) { ... } public CompletableFuture getDocument(
我正在调用一个返回 CompletableFuture 的服务。 输出结构如下。 Class Output { public String name; public Integer a
我正在尝试转换 List>至CompletableFuture> .当您有许多异步任务并且需要获取所有这些任务的结果时,这非常有用。 如果其中任何一个失败,那么最终的 future 将失败。这就是我的
我是一名优秀的程序员,十分优秀!