java.util.concurrent.Executors源码学习(三)

Executors中的重要方法(续):


8. ScheduledExecutorService newSingleThreadScheduledExecutor(ThreadFactory threadFactory)
创建一个计划任务线程池,池中的worker线程数中有一个。处理的任务放在一个延迟任务队列(DelayedWorkQueue)中,产生新线程的工厂为threadFactory。同时执行的任务将按照FIFO顺序来执行。

9. ScheduledExecutorService newScheduledThreadPool(int corePoolSize)
创建一个计划任务线程池,池中的常驻worker线程数为nThreads个,最大线程个数不限。处理的任务放在一个延迟任务队列(DelayedWorkQueue)中。
例子:


ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(10);
Runnable task = new Runnable() {
@Override
public void run() {
System.out.println("task over");
}
};
scheduler.scheduleAtFixedRate(task, 10, 10, TimeUnit.SECONDS);


上面例子中,scheduler会延迟10秒后,开始每10秒执行一次task。
10. ScheduledExecutorService newScheduledThreadPool(int corePoolSize, ThreadFactory threadFactory)
创建一个计划任务线程池,池中的常驻worker线程数为nThreads个,最大线程个数不限。处理的任务放在一个延迟任务队列(DelayedWorkQueue)中,产生新线程的工厂为threadFactory。

11. ExecutorService unconfigurableExecutorService(ExecutorService executor)
从一个指定的executor实现创建ExecutorService实现,其中只暴露了ExecutorService接口的方法,其他的方法无法访问。这样就不能对其重新配置了。

12. ScheduledExecutorService unconfigurableScheduledExecutorService(ScheduledExecutorService executor)
从一个指定的executor实现创建ScheduledExecutorService实现,其中只暴露了ExecutorService接口的方法,其他的方法无法访问。这样就不能对其重新配置了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值