如何解决TimerTask和Executors.newScheduledThreadPool1之间的区别
|| 我需要安排一些将来要做的工作。我可以通过两种方式做到这一点: 创建一个TimerTask
并执行timer.schedule(...);
使用Executors.newScheduledThreadPool(1)
:
ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);
ScheduledFuture <?> scheduleHandle = scheduler.schedule(pushExternalRunnable,runScheduleDate.getTime() - now.getTime(),TimeUnit.MILLISECONDS);
这两种将来安排工作的方式有什么区别?
解决方法
最大的区别是,Timer将在单个后台线程中调度所有任务。另一方面,ExecutorService将创建新线程(如有必要)以运行任务(达到您指定的池的大小,此时将对任务进行排队)。
,另一个区别是是否存在未捕获的异常。如果使用计时器,则终止后台线程,但不恢复后台线程。使用ScheduledExecutor(即使具有单线程配置),在发生未捕获的异常后,ScheduledExecutor也可以继续。它试图确保所需数量的线程正在运行以处理任务。
如果您想与进度交互,则ScheduledExecutor还会产生一个未来。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。