池化技术的应用很广泛,比如线程池、连接池等。在业务有需要的地方建池,将宝贵的资源重复利用,从而提升效率和性能。ThreadPoolExecutor是JAVA提供的一种线程池技术,通过使用它,我们可以很方便的建立
池化技术的应用很广泛,比如线程池、连接池等。在业务有需要的地方建池,将宝贵的资源重复利用,从而提升效率和性能。ThreadPoolExecutor是JAVA提供的一种线程池技术,通过使用它,我们可以很方便的建立线程池。
线程池处理模式
线程池类结构
定时任务
ScheduledExecutorService中有三个方法用来进行不同类型的定时任务处理:
- schedule : 在给定的延迟时间(delay)后执行任务
- scheduleAtFixedRate : 在给定的延迟时间后执行任务。并从开始执行任务时算起,经过间隔时间后再次循环的执行此任务
- scheduleWithFixedDelay : 在给定的延迟时间后执行任务。并从执行完毕任务时算起,经过间隔时间后再次循环的执行此任务
任务提交
我们可以使用execute提交的任务,但是execute方法没有返回值,所以无法判断任务知否被线程池执行成功。通过以下代码可知execute方法输入的任务是一个Runnable类的实例。
我们也可以使用submit方法来提交任务,它会返回一个future,那么我们可以通过这个future来判断任务是否执行成功,通过future的get方法来获取返回值,get方法会阻塞住直到任务完成,而使用get(long timeout, TimeUnit unit)方法则会阻塞一段时间后立即返回,这时有可能任务没有执行完。
任务关闭
我们可以通过调用线程池的shutdown或