线程池的创建与使用

void execute(Runnable run)方法处理Runnbale任务
Future<> submit(Callable<> task)方法处理Callable任务
void shutdown()结束线程池
List<\Runnable> shutdownNow()立即结束线程池,不管任务是否执行完毕

//创建线程池的一种方式
ExecutorService pool = new ThreadPoolExecutor(2,5,1,
                TimeUnit.HOURS,new ArrayBlockingQueue<>(2),
                Executors.defaultThreadFactory(),new ThreadPoolExecutor.AbortPolicy());
 //构造器(核心线程数量,最大线程数量,临时线程的存活时长,
 //临时线程的存活时间单位,等待任务队列,线程池工厂,任务拒绝策略)
 //任务等待队列常用:new ArrayBlockingQueue<>(等待任务数量),new LinkedBlockingQueue<>()没有数量限制
 //new ThreadPoolExecutor.AbortPolicy()当线程在忙,任务队列也满了,新任务来了会抛出异常

Runnable target = new MyRunnable();
//execute()方法处理Runnbale任务
//创建线程任务
pool.execute(target);
//线程池分配线程执行任务
pool.execute(target);
//2个核心线程都在忙,若新任务来则创建临时线程
pool.execute(target);
pool.execute(target);
pool.execute(target);
//三个临时线程也在忙,若新任务来则加入任务队列
pool.execute(target);
pool.execute(target);
//任务队列已满,若新任务来则拒绝并抛出异常
pool.execute(target);
//拒绝新任务,并抛出异常

Future<String> f1 = pool.submit(new CallableThread(100));
        //调用submit()方法处理Callable任务对象,返回Future对象
        Future<String> f2 = pool.submit(new CallableThread(200));
        Future<String> f3 = pool.submit(new CallableThread(300));
        Future<String> f4 = pool.submit(new CallableThread(400));
        f1.get();
        //调用返回的Future对象的get()方法获得任务的返回结果
        f2.get();
        f3.get();
        f4.get();

面试问题:
什么时候创建临时线程?
答:当新任务提交时,核心线程都在忙,任务队列也满了后,并且还可以创建临时线程,此时才会创建临时线程

什么时候会开始拒绝新任务?
答:当核心线程和临时线程都在忙,任务队列也满了,新来的任务才会开始拒绝新任务

在这里插入图片描述
在这里插入图片描述
创建线程池的别的方法:
在这里插入图片描述
在这里插入图片描述

核心任务线程数量配置多少合适?

计算密集型任务:核心线程数量 = CPU核心数(逻辑处理器)+1;
IO密集型任务 : 核心线程数 = CPU核心数*2;

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值