Java中的四种线程池 . ExecutorService

Java中的四种线程池 . ExecutorService

 

1.缓存线程池

缓存线程池的长度无限制,在执行线程时,先判断线程池中是否存在空闲线程,如果存在就直接使用,不存在则创建线程再使用。

ExecutorService service = Executors.newCachedThreadPool();
service.execute(new Runnable() {
    @Override
    public void run() {
        System.out.println("线程的名称:"+Thread.currentThread().getName());
    }
});

2.定长线程池

定长线程池在创建时需要定义线程池的长度,在执行线程时,先判断线程池中是否存在空闲线程,如果存在就直接使用,不存在则需要判断线程池是否已满,如果已满则等待线程池存在空闲线程,未满则创建线程放入线程池再使用。

ExecutorService service = Executors.newFixedThreadPool(2);
service.execute(new Runnable() {
    @Override
    public void run() {
        System.out.println("线程的名称:"+Thread.currentThread().getName());
    }
});

3.单线程线程池

单线程线程池与定长线程池相似,只是长度为一。在执行线程时,先判断线程池中的线程是否是空闲线程,如果空闲就直接使用,不是空闲则等待线程空闲。

ExecutorService service = Executors.newSingleThreadExecutor();
service.execute(new Runnable() {
    @Override
    public void run() {
        System.out.println("线程的名称:"+Thread.currentThread().getName());
    }
});

4.周期性任务定长线程池

周期性任务定长线程池在执行线程时,先判断线程池中是否存在空闲线程,如果存在就直接使用,不存在则需要判断线程池是否已满,如果已满则等待线程池存在空闲线程,未满则创建线程放入线程池再使用。

定时执行, 当某个时机触发时, 自动执行某任务 

ScheduledExecutorService service = Executors.newScheduledThreadPool(2);

/**
* 定时执行
* 参数1. runnable类型的任务
* 参数2. 时长数字
* 参数3. 时长数字的单位
*/
service.schedule(new Runnable() {
    @Override
    public void run() {
        System.out.println("线程的名称:"+Thread.currentThread().getName());
    }
},5,TimeUnit.SECONDS);

/**
* 周期执行
* 参数1. runnable类型的任务
* 参数2. 时长数字(延迟执行的时长)
* 参数3. 周期时长(每次执行的间隔时间)
* 参数4. 时长数字的单位
*/
service.scheduleAtFixedRate(new Runnable() {
    @Override
    public void run() {
        System.out.println("线程的名称:"+Thread.currentThread().getName());
    }
},5,2,TimeUnit.SECONDS);

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值