Executor 生命周期

对于生命周期,我想我们已经听得够多了。比如Android的Activity生命周期(onCreate->onStart->onResume...),比如Servlet容器中的Servlet生命周期(init->service->destroy)。

了解一个对象的生命周期,会加深你对该对象所属框架的认识。因此,要想掌握某个对象,了解它的生命周期是必要的。

对于executor framework里的执行者executor,它也有自己的生命周期。但是它的生命周期被定义在ExecutorService接口里。

public interface ExecutorService extends Executor {
void shutdown();
List<Runnable> shutdownNow();
boolean isShutdown();
boolean isTerminated();
boolean awaitTermination(long timeout, TimeUnit unit)
throws InterruptedException;
// ... additional convenience methods for task submission
}

可以看出executor一共有三个状态,running,shutting down and terminated。

如果利用executors创建了某个实例,比如newCachedThreadPool(size)。该实例内部维护了指定大小的工作线程(Worker Threads)以及工作队列(work queue)。对于JVM,如果至少存在一个非守护线程(Non-dameon thread),则该虚拟机不会停止。因此,如果想要终止JVM,需要调用该实例的shutdown方法(或者shutdownNow方法)。二者的区别是:前者是优雅地结束,所谓优雅,就是说拒绝接受新的task,但是允许已经接纳的task继续运行(包括在工作队列里还没运行的task)。后者是突然地(abruptly)终止,不仅不接受新来的task,即使仍然有task在运行,也必须把它“枪毙”。注意到该方法返回了一个Runnable的列表,该列表的内容即为受影响的task。当调用了shutdown后,executor便进入了terminated状态,调用isTerminated方法将返回true。awaitTermination方法提供了一个同步,等到executor进入terminated状态立即返回(return)。因此一个通常的结束方式是调用shutdown方法后紧接着调用awaitTermination方法。

	public static void main(String[] args) throws InterruptedException {

		ExecutorService exec = Executors.newCachedThreadPool();
//		exec.submit(task);
		exec.shutdown(); // 优雅终止
		exec.awaitTermination(1, TimeUnit.DAYS);
		System.out.println("The end of Main");
	}


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值