[英]Run more than one thread using ScheduledExecutorService with same period
我可以在我的应用程序中使用多个服务器。 对于每台服务器,我需要在一秒钟内从服务器中获取一些信息到解耦的线程中。
如何使用ScheduledExecutorService
启动多个Runnable
? 我应该为每个线程使用排他的执行器,还是可以使用一个执行器实例并将需要每秒运行的所有可运行对象传递给它?
看来您正在寻找的是ScheduledExecutorService#scheduleAtFixedRate()
:
创建并执行一个周期性操作,该操作将在给定的初始延迟后首先启用,然后在给定的时间段内启用; 也就是说执行将在
initialDelay
initialDelay+period
,initialDelay + 2 * period
等之后开始。
这是一个简单的例子:
ScheduledExecutorService executor = Executors.newScheduledThreadPool(NUMBER_OF_THREADS);
executor.scheduleAtFixedRate(new Runnable() {
@Override
public void run() {
// runnable logic
}
}, 0, 1, TimeUnit.SECONDS);
您应该在应用程序中使用一个ExecutorService
。 有关该方法的更多信息,请参见Javadocs。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.