固定数量线程池(newFixedThreadPool)

固定数量线程池(newFixedThreadPool)

package com.zhw.learning.thread;

import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

/**
 * @author zhw
 * 创建了一个固定大小的线程池,每次提交一个任务就创建一个线程,
 * 直到线程达到线程池的最大值nThreads。线程池的大小一旦达到最大值后,
 * 再有新的任务提交时则放入无界阻塞队列中,等到有线程空闲时,
 * 再从队列中取出任务继续执行。
 *
 * Executors.newFixedThreadPool(int nThreads)源码:
 * public static ExecutorService newFixedThreadPool(int nThreads) {
 *         return new ThreadPoolExecutor(nThreads, nThreads,
 *                                       0L, TimeUnit.MILLISECONDS,
 *                                       new LinkedBlockingQueue<Runnable>());
 *     }
 */
public class FixedThreadPoolTest {

    public static void main(String[] args) {
        ExecutorService fixedThreadPool = Executors.newFixedThreadPool(3);

        for (int i=0;i<5;i++){
            final int index = i;
            fixedThreadPool.execute(new Runnable() {
                @Override
                public void run() {
                    try {
                        SimpleDateFormat sdf = new SimpleDateFormat(
                                "HH:mm:ss");
                        System.out.println("运行时间: " +
                                sdf.format(new Date()) + " " + index);
                        Thread.sleep(2000);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            });
        }

        fixedThreadPool.shutdown();
    }

}

创建了一个固定大小为3的线程池,然后在线程池提交了5个任务。在提交第4个任务时,因为线程池的大小已经达到了3并且前3个任务在运行中,所以第4个任务被放入了队列,等待有空闲的线程时再被运行。运行结果如下(注意前3个任务和后2个任务的运行时间):
在这里插入图片描述

发布了31 篇原创文章 · 获赞 5 · 访问量 623

猜你喜欢

转载自blog.csdn.net/qq_37365741/article/details/103889762
今日推荐