java创建线程池几种方式_java知识总结-创建线程池的6种方式

一、创建线程池的6种方式:

Executors.newCachedThreadPool();

创建一个可缓存线程池,应用中存在的线程数可以无限大

Executors.newFixedThreadPool(2)

创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。

Executors.newScheduledThreadPool(2)

创建一个定长线程池,支持定时及周期性任务执行。

4 Executors.newSingleThreadExecutor();

创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,

保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。

5 Executors.newSingleThreadScheduledExecutor();

创建一个单例线程池,定期或延时执行任务。

6 Executors.newWorkStealingPool(3);

创建一个带并行级别的线程池,并行级别决定了同一时刻最多有多少个线程在执行,如不穿如并行级别参数,将默认为当前系统的CPU个数。

二、代码

线程代码

public class ThreadForpools implements Runnable {

private Integer index;

public ThreadForpools(Integer index) {

this.index = index;

}

@Override

public void run() {

/***

* 业务......省略

*/

try {

System.out.println(index + " 开始处理线程!!!");

Thread.sleep(index * 2000); //等2秒方便参观

System.out.println(index + " 我的线程标识是:" + this.toString());

} catch (InterruptedException e) {

e.printStackTrace();

}

}

}

方式一:newCachedThreadPool

import java.util.concurrent.ExecutorService;

import java.util.concurrent.Executors;

/**

* 描述:newCachedThreadPool

* 创建一个可缓存线程池,应用中存在的线程数可以无限大

*/

public class ThreadpoolsCached {

public static void main(String[]args)

{

ExecutorService newCachedThreadPool = Executors.newCachedThreadPool();

for(int i=0;i<10;i++)

{

final int index=i;

newCachedThreadPool.execute(new ThreadForpools(index));

}

}

}

借助jconsole工具看看线程,由下图可看。所有的线程一次性已经加载进来了。

线程执行完了,线程数也相应减少了,最后程序也就结束了。

b54669893e37

2.jpg

方式二:newFixedThreadPool

import java.util.concurrent.ExecutorService;

import java.util.concurrent.Executors;

/**

* 描述:创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。

*/

public class ThreadpoolsFixed {

public static void main(String[]args)

{

//线程池允许同时存在两个线程

ExecutorService newFixedThreadPool = Executors.newFixedThreadPool(2);

for(int i=0;i<10;i++)

{

final int index=i;

newFixedThreadPool.execute(new ThreadForpools(index));

}

}

}

再看看jconsole的线程情况。只有两个线程。线程执行完后还会处于等待的状态。

b54669893e37

线程

方式三:newScheduledThreadPool

import java.util.concurrent.Executors;

import java.util.concurrent.ScheduledExecutorService;

import java.util.concurrent.TimeUnit;

/**

* 描述:创建一个定长线程池,支持定时及周期性任务执行。延迟执行示例代码如下

*/

public class ThreadpoolsScheduled {

/**

* 我们获取四次次线程,观察4个线程地址

* @param args

*/

public static void main(String[]args)

{

ScheduledExecutorService newScheduledThreadPool = Executors.newScheduledThreadPool(2);

for(int i=0;i<10;i++)

{

final int index=i;

//延迟三秒执行

newScheduledThreadPool.schedule(new ThreadForpools(index),3, TimeUnit.SECONDS);

}

}

}

方式四:newSingleThreadExecutor

import java.util.concurrent.ExecutorService;

import java.util.concurrent.Executors;

/**

* 描述:创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,

* 保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。

*/

public class ThreadpoolsSingle {

public static void main(String[]args) {

ExecutorService newSingleThreadExecutor = Executors.newSingleThreadExecutor();

for(int i=0;i<10;i++)

{

final int index=i;

newSingleThreadExecutor.execute(new ThreadForpools(index));

}

}

}

方式五:newSingleThreadScheduledExecutor

import java.util.concurrent.ExecutorService;

import java.util.concurrent.Executors;

import java.util.concurrent.ScheduledExecutorService;

import java.util.concurrent.TimeUnit;

/**

* 描述:创建一个单例线程池,定期或延时执行任务。

*/

public class ThreadpoolsSingleThreadScheduled {

/**

* 我们获取四次次线程,观察4个线程地址

* @param args

*/

public static void main(String[]args) {

ScheduledExecutorService scheduledExecutorService = Executors.newSingleThreadScheduledExecutor();

for(int i=0;i<10;i++)

{

final int index=i;

scheduledExecutorService.schedule(new ThreadForpools(index),3, TimeUnit.SECONDS);

}

}

}

方式六:

···

import java.util.Date;

import java.util.concurrent.ExecutorService;

import java.util.concurrent.Executors;

/**

描述:创建一个带并行级别的线程池,并行级别决定了同一时刻最多有多少个线程在执行,

如不穿如并行级别参数,将默认为当前系统的CPU个数。

*/

public class ThreadpoolsWorkStealingPool {

public static void main(String[] args) throws Exception {

// 设置并行级别为2,即默认每时每刻只有2个线程同时执行

ExecutorService executorService = Executors.newWorkStealingPool(3);

for (int i = 1; i <= 50; i++) {

final int count=i;

executorService.submit(new ThreadForpools(count));

}

while(true){

//主线程陷入死循环,来观察结果,否则是看不到结果的

}

}

}

···

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值