- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个具有invoke方法的函数,该函数在内部调用soap API,
而且执行过程大约需要22秒,代码中几乎没有其他方法,
因此,完全deleteSoemthing()(下面的代码)方法大约需要24秒,
现在,我尝试在单独的线程中运行耗时方法,
所以我的假设是,即使它是单独的线程,它也会被优化为2秒,因为它从总共24秒中花费了22秒。
因此可能需要22秒,而不是24秒,因为它是并行运行的。
但是,当我通过 postman 运行此程序时,只需2秒钟即可执行,这意味着响应将在2秒钟内返回。并且单独的线程保持运行(当我通过调试检查时)。
因此,我的怀疑是,主线程是否不等待此任务完成并将响应发送回去。
或仅发送响应并在后台继续运行异步任务
void deleteSomething(){
CompletableFuture<Void> completableFuture = CompletableFuture.runAsync(() -> {
try {
invoke("invoking a soap API"));
} catch (Exception e) {
e.printStackTrace();
}
});
//some other code
}
最佳答案
如果您希望主线程(请求)并行处理“其他代码”和“调用SOAP API”,然后合并并将响应返回给最终用户,则此方法将无效。
当我们创建CompletableFuture实例时,它将在另一个线程中分离计算并立即返回Future。如果需要阻止结果,则需要在其上调用get方法。但是,此过程仍需要22 + 2 = 24秒才能返回响应。
要并行运行这两个任务,您应该创建两个可调用的,并将其提交给 ExecutorService
例如。
public void deleteSomething(){
ExecutorService executorService = Executors.newFixedThreadPool(2);
Collection<Callable<Void>> callables = new ArrayList<>();
callables.add(() -> doSomeOtherTask());
callables.add(() -> invokeSoapApi());
try {
List<Future<Void>> taskFutureList = executorService.invokeAll(callables);
taskFutureList.get(0).get();
taskFutureList.get(1).get();
} catch (InterruptedException | ExecutionException e) {
//error
}
}
public Void doSomeOtherTask() {
//some other code
return null;
}
public Void invokeSoapApi() {
//soap api call
return null;
}
请注意,线程池应在应用程序启动时创建。
@Service
public class MyService {
...
...
private ExecutorService executorService = Executors.newFixedThreadPool(2);
...
...
//your methods
}
关于java - 主线程不等待CompletableFuture.runAsync()并返回响应,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62859977/
我第一次用 GWT.RunAsync 拆分了我的模块以更快地加载。但是一旦加载,我想加载所有其他代码拆分,因为用户将空闲一段时间,并且在需要时他可以更快地处理这些部分。 有人尝试过这样做吗?有什么简单
我正在构建一个将运行 BackgroundService 的 .NET Core 3.1 应用程序在 Docker 容器中。虽然我已经为 BackgroundService 实现了启动和关闭任务,并且
我有一个具有invoke方法的函数,该函数在内部调用soap API, 而且执行过程大约需要22秒,代码中几乎没有其他方法, 因此,完全deleteSoemthing()(下面的代码)方法大约需要24
我正在尝试使用 CompletableFuture 在 JavaFX Canvas 上写入大量像素,尽管没有抛出异常,但我的方法似乎并未完成其任务。 我是异步编程的新手,不确定应该从哪里开始,但我认为
上下文:我已阅读 this SO 线程讨论 CompletableFuture 和 Thread 之间的差异。 但我试图了解何时应该使用 new Thread() 而不是 runAsync()。 我知
早上好, 我还没有完全掌握 CompletableFutures 的窍门(我是一位经验丰富的开发人员,但我并不觉得它们特别直观!)。 给出以下代码片段: public CompletionStage
我正在尝试在初始化不同子系统时使用 runAsync 来修改应用程序的加载性能,但我有几个问题: 当callback的onSuccess方法中调用的代码被拆分到另一个下载片段中时,被调用的类、子类、方
我写了下面的代码 ExecutorService service = Executors.newFixedThreadPool(3); Runnable task = () -> { System.o
如何停止 RunAsync? CancellatioTokenSource cts = new CancellationTokenSource(); //I thought that it's mus
我在网上搜索过关于ThreadHelper.JoinableTaskFactory.RunAsync的信息很少 如果我有以下代码,Test1 在 MainThread 上运行: public bool
我的代码运行良好: String name = "Oscar"; CompletableFuture.runAsync(() -> doX(name)); 现在我需要向 name 变量添加一些逻辑:
先决条件(一般描述): 1.静态类字段 static List ids = new ArrayList<>(); 2. CompletableFuture#runAsync(Runnable runn
我刚刚读了the documentation关于 CompletableFuture::runAsync 并且被解释弄糊涂了。这是那里写的: Returns a new CompletableFutu
我是 C# 的新手,目前正在做一个需要 BackgroundWorkers 的项目.我发现 BackgroundWorker RunWorkerAsync只需将一个对象作为参数。但在某些情况下,我需要
我有一组在 SQLite 异步方法中运行的 INSERT 语句: SQLite3JS.openAsync(path).then(function (db) { $.each(sql, func
我尝试使用 Kotlin 和 TornadoFX 库中的套接字连接来实现聊天应用程序以制作 GUI。 当我尝试启动客户端时出现问题,因为它一直在等待来自服务器的消息,尽管我将更新标签并接收消息的代码放
我的要求是每 30 秒轮询一次 MongoDB,以了解集合中的任何数据更改。我已使用 Java CompletableFuture.runAsync 来实现此功能,如下面捕获的代码所示。我已经测试运行
我正在使用 Dispatcher.RunAsync() 从后台线程显示 MessageDialog。但我无法弄清楚如何返回结果。 我的代码: bool response = f
假设我有这个示例代码,并且在 runAsync 中遇到异常。我的问题是这个异常是否会阻止 thenRun 被执行,因为 thenRun 与此代码的调用者方法在同一线程中运行。 private void
在等待 Dispatcher.RunAsync 时,继续会在工作安排时发生,而不是在工作完成时发生。我如何等待工作完成? 编辑 我最初的问题假设过早继续是由 API 的设计引起的,所以这是真正的问题。
我是一名优秀的程序员,十分优秀!