Java多线程(3):ThreadPool(下)

Java多线程(3):ThreadPool(下)

您好,我是湘王,这是我的云海天,欢迎您来,欢迎您再来~

 

除了可以通过ThreadPoolExecutor自定义线程池外,同Stream API中的Collectors一样,多线程里的Executors类也提供了一组相关的线程池工具,可以直接拿来用,不用考虑用什么队列合适的问题。

Javac除了传统的四大线程池工具:

1、newFixedThreadPool定长线程池

2、newCachedThreadPool缓存线程池

3、newSingleThreadExecutor单线程线程池

4、newScheduledThreadPool任务调度线程池

还包括了Java8新增的newWorkStealingPool抢占式线程池,目前这个用的不多,还是以之前的四大类线程池为主。

 

newFixedThreadPool定长线程池,顾名思义,就是它的线程池的大小是固定的,好比一个水池只能装10个立方的水量,11个立方肯定就装不下了。在newFixedThreadPool定长线程池中,c=m(也就是corePoolSize = maximumPoolSize),默认为无界队列,用代码来示例:

// 定长线程池
ExecutorService service1 = Executors.newFixedThreadPool(3);
for (int i = 0; i < 10; i++) {
    System.out.println("创建线程 " + i);
    service1.execute(() -> System.out.println("当前线程 " + Thread.currentThread().getName()));
}
service1.shutdown();
hmoban主题是根据ripro二开的主题,极致后台体验,无插件,集成会员系统
自学咖网 » Java多线程(3):ThreadPool(下)