线程池

2020-01-11  本文已影响0人  陈小胖lx

在我们的开发中经常会使用到多线程。像网络请求等一些耗时的操作我们必须在子线程中运行。我们往往会通过new Thread来开启一个子线程,待子线程操作完成以后通过Handler切换到主线程中运行。这么以来我们无法管理我们所创建的子线程,并且无限制的创建子线程,它们相互之间竞争,很有可能由于占用过多资源而导致死机或者OOM。所以在Java中为我们提供了线程池来管理我们所创建的线程。

一.线程池的优势

①降低资源的损耗

②提高响应速度

③方便线程并发数的管控

二.四种线程池类

1. newFixedThreadPool(固定线程数)

ExecutorService service = Executors.newFixedThreadPool(4);

在这个线程池中,所容纳的最大线程数就是我们指定的核心线程数。线程池没有超时机制所以如果线程池处于空闲状态线程池不会被回收,除非线程池被关闭。如果所有的线程处于活动状态,新任务处于等待状态直到有线程空闲下来

2.newCachedThreadPool()

newThreadPoolExecutor(0, Integer.MAX_VALUE,60L, TimeUnit.SECONDS,newSynchronousQueue());

这个线程池 核心线程数为0 所能容纳最大线程数 Integer.MAX_VALUE 线程池最大超时时间为60s。当线程池中的线程都处于活动状态的时候,线程池就会创建一个新的线程来处理任务。

3. newScheduleThreadPool

通过Executors中的newScheduledThreadPool方法来创建。

它的核心线程数是固定的,对于非核心线程几乎可以说是没有限制的,并且当非核心线程处于限制状态的时候就会立即被回收。

schedule(Runnable command, long delay, TimeUnit unit):延迟一定时间后执行Runnable任务;

schedule(Callable callable, long delay, TimeUnit unit):延迟一定时间后执行Callable任务;

scheduleAtFixedRate(Runnable command, long initialDelay, long period, TimeUnit unit):延迟一定时间后,以间隔period时间的频率周期性地执行任务;

scheduleWithFixedDelay(Runnable command, long initialDelay, long delay,TimeUnit unit):与scheduleAtFixedRate()方法很类似,但是不同的是scheduleWithFixedDelay()方法的周期时间间隔是以上一个任务执行结束到下一个任务开始执行的间隔,而scheduleAtFixedRate()方法的周期时间间隔是以上一个任务开始执行到下一个任务开始执行的间隔,也就是这一些任务系列的触发时间都是可预知的。

ScheduledExecutorService功能强大,对于定时执行的任务,建议多采用该方法。

4. newSingleThreadExecutor

在这个线程池中核心线程只有一个。newSingleThreadExecutor将所有的外界任务统一到一个线程中支持,所以在这个任务执行之间我们不需要处理线程同步的问题。

上一篇 下一篇

猜你喜欢

热点阅读