Java线程池的使用
顾名思义,池子里面有多个线程,但是会有不同的池子,那么就简单的介绍下池子的种类
线程池的种类
Java通过Executors提供四种线程池。分别为:
Executors.newCachedThreadPool()
创建一个可缓存线程的线程池,可灵活创建、回收线程。
Executors.newFixedThreadPool(int num)
创建一个定长线程的线程池,可以控制最大并发数。
Executors.newScheduledThreadPool(int num)
创建一个定长线程的线程池,支持自定义线程定时执行任务。
Execuotrs.newSingleThreadExecutor()
创建一个只有一个线程的线程池。
示例代码
Executors.newCachedThreadPool()
可缓存线程的线程池,可灵活创建、回收线程
- public class ThreadPoolExecutorTest {
- public static void main(String[] args) {
- // 该线程池中的线程数量理论为无限大
- ExecutorService cachedThreadPool = Executors.newCachedThreadPool();
- for (int i = 0; i < 10; i++) {
- final int index = i;
- try {
- Thread.sleep(index * 1000);
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- // 当执行第二个任务时,第一个任务已经执行完成,所以第二个任务会复用第一个线程。而不用创建新的线程
- cachedThreadPool.execute(new Runnable() {
- public void run() {
- System.out.println(index);
- }
- });
- }
- }
- }
Executors.newFixedThreadPool(int num)
定长线程的线程池,可以控制最大并发数,超出的线程会在队列中等待
- public class ThreadPoolExecutorTest {
- public static void main(String[] args) {
- ExecutorService fixedThreadPool = Executors.newFixedThreadPool(3);
- for (int i = 0; i < 10; i++) {
- final int index = i;
- fixedThreadPool.execute(new Runnable() {
- // 线程池中的线程数量为3个,所以每两秒打印三个数字
- public void run() {
- try {
- System.out.println(index);
- Thread.sleep(2000);
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- }
- });
- }
- }
- }
Executors.newScheduledThreadPool(int num)
创建一个定长线程的线程池,支持自定义线程延迟执行任务、周期执行任务
- public class ThreadPoolExecutorTest {
- public static void main(String[] args) {
- ScheduledExecutorService scheduledThreadPool = Executors.newScheduledThreadPool(5);
- scheduledThreadPool.schedule(new Runnable() {
- public void run() {
- System.out.println("delay 3 seconds");
- }
- // 表示每个线程延迟三秒执行
- }, 3, TimeUnit.SECONDS);
- // 表示每个线程延迟一秒,每三秒执行一次
- //}, 1, 3, TimeUnit.SECONDS);
- }
- }
Execuotrs.newSingleThreadExecutor()
创建一个只有一个线程的线程池
- public class ThreadPoolExecutorTest {
- public static void main(String[] args) {
- ExecutorService singleThreadExecutor = Executors.newSingleThreadExecutor();
- for (int i = 0; i < 10; i++) {
- final int index = i;
- singleThreadExecutor.execute(new Runnable() {
- public void run() {
- try {
- System.out.println(index);
- Thread.sleep(2000);
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- }
- });
- }
- }
- }