gpt4 book ai didi

java - 在以下情况下建议使用 Thread.sleep()

转载 作者:行者123 更新时间:2023-11-29 06:51:53 24 4
gpt4 key购买 nike

我有一个调用此方法的网络服务

public void process(Incoming incoming) {
// code to persist data
...
Thread.sleep(20000);
// check persisted data and if status != CANCELLED then process
}

要求是我必须等待20秒(因为业务很有可能在20秒内发送取消请求,这种情况我们不应该处理)。

我知道 Thread.sleep() 在时间到之前甚至不会打扰 cpu。

  • 但问题是,由于它是从网络服务调用的,这些线程可能来自某种池,如果有大量请求,它们可能会耗尽?
  • 或者新的 servlet 容器是否会在耗尽时自动创建额外的线程,我们可以编写这种代码而不必担心这些事情?
  • 安排一个在 20 秒后运行的异步任务是否是更好的选择?同样,我们必须有一个线程池来执行这些任务。

最佳答案

Does scheduling an asynchronous task which runs after 20 seconds a better option? Here also, we have to have a Thread pool to execute these tasks anyway.

是的,它是一个更好的选择,因为使用 Thread.sleep(20000); 您会为每个请求阻塞一个线程。使用计划线程池,您将任务添加到某种队列,稍后它们将使用恒定数量的线程执行 - 因此不可能耗尽所有可用线程。

关于java - 在以下情况下建议使用 Thread.sleep(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45275568/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com