当前位置:网站首页>异步编程概览
异步编程概览
2022-08-04 13:48:00 【WihauShe】
新线程的实现
- 继承Thread类
- 实现Runnable接口
- 实现Callable [+ FutureTask]
- 利用线程池
线程池实现类
- ThreadPoolExecutor实现类继承自AbstractExecutorService抽象类
- AbstractExecutorService实现了ExecutorService接口
- ExecutorService接口继承了Executor接口
参数
- 核心线程数 (corePoolSize)
- 最大线程数量(maximumPoolSize)
- 多余线程存活时间(keepAliveTIme)
- 时间单位(unit)
- 阻塞队列(workQueue)
- 线程工厂(threadFactory)
- 拒绝策略(handler)
拒绝策略
- 抛出异常(AbortPolicy),默认
- 直接抛弃(DiscardPolicy)
- 丢弃队列中最早的任务(DiscardOldestPolicy)
- 使用当前线程执行(CallerRunsPolicy)
工作流程
- 如果核心线程数未满,直接利用核心线程执行,否则转下步
- 如果阻塞队列未满,直接进入阻塞队列,否则转下步
- 如果最大线程数未满,直接创建新线程执行任务,否则执行拒绝策略
异步类
相关实现关系
- FutureTask类实现了RunnableFuture接口
- RunnableFuture接口继承了Runnable和Future接口
- CompletableFuture类实现了Future和CompletionStage接口
回调方法
- whenComplete (当前任务成功完成后获取返回值和异常) 和 whenCompleteAsync (异步获取)
- exceptionally (设定当出现异常返回的默认值)
- handle (接收返回值和异常进行处理)
串行化
- thenApply (接收上一步的返回值并有返回值)
- thenApplyAsync
- thenAccept (接收上一步的返回值无返回值)
- thenAcceptAsync
- thenRun (直接执行下一步的任务)
- thenRunAsync
组合任务-都完成
- thenCompose (组合两个future,并将前一个任务的返回结果作为下一个任务的参数,存在先后顺序)
- thenCombine (组合两个future,获取它们的返回值,并返回当前任务的返回值)
- thenCombineAsync
- thenAcceptBoth (组合两个future,获取它们的返回值,没有返回值)
- thenAcceptBothAsync
- runAfterBoth (组合两个future,不需要返回值直接处理)
- runAfterBothAsync
组合任务-任意一个完成
- applyToEither (组合两个future,任意一个完成获取它的返回值,并返回当前任务的返回值)
- applyToEitherAsync
- acceptEither (组合两个future,获取一个future的返回值,并且没有返回值)
- acceptEitherAsync
- runAfterEither (组合两个future,有一个完成后直接处理,并且没有返回值)
- runAfterEitherAsync
多任务组合
- allOf (等待所有任务完成)
- anyOf(任意一个任务完成则结束)
边栏推荐
猜你喜欢
Why don't young people like to buy Mengniu and Yili?
《社会企业开展应聘文职人员培训规范》团体标准在新华书店上架
烂大街的缓存穿透、缓存击穿和缓存雪崩,你真的懂了?
Haproxy搭建web群集
干掉visio,这个画图神器真的绝了
Programmer Qixi Gift - How to quickly build an exclusive chat room for your girlfriend in 30 minutes
从理论到实践:MySQL性能优化和高可用架构,一次讲清
Is there a replacement for the LM2596?LM2576 can
如何才能有效、高效阅读?猿辅导建议“因材因时施教”
SLAM 05.视觉里程计-2-特征法
随机推荐
C# 动态加载卸载 DLL
Programmer Qixi Gift - How to quickly build an exclusive chat room for your girlfriend in 30 minutes
MySQL性能指标TPS\QPS\IOPS如何压测?
Interviewer: How to view files containing abc string in /etc directory?
关于redis的几件小事(五)redis保证高并发以及高可用
"C pitfalls and pitfalls" reading summary
文字编码 - XML 教程
汉诺塔怎么玩
Cockpit human-computer interaction "undercurrent", voice "down", multi-modal "up"
阴影初始化【5】
阿里老鸟终于把测试用例怎么写说的明明白白了,小鸟必看
干掉visio,这个画图神器真的绝了
第四讲 SVN
JSX use
Is there a replacement for the LM2596?LM2576 can
How to stress the MySQL performance indicators TPS\QPS\IOPS?
idea永久激活教程(新版)
2546 饭卡(01背包,挺好的)
LeetCode 1403 非递增顺序的最小子序列[贪心] HERODING的LeetCode之路
SMART S7-200PLC串行自由口通讯(耐压测试仪)