13、Executor

###Executor有几大部分组成
1、任务:任务的执行需要实现Runable 接口或Callable接口
2、任务的执行:Executor的子类 ExcutorService更强大。
有两个关键类实现了接口:ThreadPoolExecutor 和ScheduledThreadPoolExecutor;
3、异步计算的结果:包括接口Future 和实现Future接口的FutureTask(实现了RunableFuture,RunableFuture继承了Runable接口和Future接口);

###框架
在这里插入图片描述
###应用

Executor.submit() 有返回值的
Executor.execute()没有返回值的

###线程
创建线程的3种方式
1、继承Thread 类,很少用,因为有局限性。
2、实现Runable接口,线程池就是实现runable接口的
3、实现Callable接口,有返回值的。

###固定线程池(FixedThreadPool)
在这里插入图片描述

固定线程池的组成:
1、LinkedBlockingQueue(有界阻塞队列)
2、corePool

为什么使用无解队列会使内存崩溃
1、任务进入线程池,会先看coresize(核心线程数)
2、如果核心线程数满了,则会进入队列
3、有界队列里,队列数满了,会看最大线程数是否满了,如果最大线程未满,则直接创建线程
如果最大线程满了,则实行拒绝策略(抛异常,不会排队,不会增加内存)
如果是无解队列,则队列永远都不会满,那么数据量大的情况下,会内存崩溃,影响系统运行

###调度线程池(ScheduledThreadPoolExecutor)
调度线程池的组成:
1、delayQueue 延时队列(无界队列)
2、corePool

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值