终于可以愉快的撸Java异步代码了!
异步响应式编程可以极大的提高系统的并发呑吐量,但由于Java没有类似于其他语言的Async/Await机制,所以只能通过CompletableFuture.thenXXX()来串联各个异步任务,这给习惯了写同步增删改查的小伙伴们带来了些小麻烦。如果说C#基于状态机在编译时实现了await转换,那么Java肯定也可以基于相同的原理实现await,作者上网一搜果然找到了ea-async,使用与C#相同的方式实现了await异步方法,这回终于可以愉快的撸Java异步代码了。
一、 示例代码
举个扣减库存并保存订单的例子,在没有await方式下的示例代码如下:
public CompletableFuture<?> saveOrder(Order order) {
//1.开始事务
return DataStore.DemoDB.beginTransaction().thenCompose(txn -> {
//2.扣库存
var cmd = new SqlUpdateCommand<Order>();
cmd.update(e -> e.Stock = e.Stock - order.Quantity); //当前量扣除订单量
cmd.where(e -> e.ProductId == order.ProductId);
var outs = cmd.output(e -> e.Stock);
return cmd.execAsync(txn).thenCompose(rows -> {
//3.判断库存
if (rows == 0 || outs.get(0) < 0)
return CompletableFuture.failedFuture("库存不足");
//4.保存订单
return order.saveAsync(txn);
}).thenCompose(r -> txn.commitAsync()); //5.递交事务
}).thenApply(r -> "Done.");
}
WTF! 一层套一层的回调,这还只是个简单的例子啊。但是如果使用await的方式,业务逻辑就变得清爽多了:
import static sys.Async.await;
public CompletableFuture<?> saveOrder(Order order) {
//1.开始事务
var txn = await(DataStore.DemoDB.beginTransaction());
//2.扣库存
var cmd = new SqlUpdateCommand<Order>();
cmd.update(e -> e.Stock = e.Stock - order.Quantity); //当前量扣除订单量
cmd.where(e -> e.ProductId == order.ProductId);
var outs = cmd.output(e -> e.Stock);
var rows = await(cmd.execAsync(txn));
//3.判断库存
if (rows == 0 || outs.get(0) < 0)
return CompletableFuture.failedFuture("库存不足");
//4.保存订单
await(order.saveAsync(txn));
//5.递交事务
await(txn.commitAsync());
return CompletableFuture.completedFuture("Done.");
}
二、 实现原理
核心思想没有变,还是代码分析转换。作者原本想利用JDT在源码层进行await转换,但是工作量还是比较大的,在这里感谢github/ea-async项目,使得作者只修改了十几行代码就实现了上述效果,具体转换过程如下:
- 服务模型的虚拟代码经过JDT分析、转换、编译为class文件(参考前篇说明);
- 调用ea-async的Transformer类直接分析与转换class文件内的await方法调用,生成新的class文件。
具体参考源码PublishService的compileService()及transformAsync()方法。
三、 本篇小结
先解释一下上篇"优雅的Java ORM"小伙伴们的评论,有说这么多ORM干吗还要造一个的,也有说不够"优雅"的,其实造轮子最根本的原因是:异步支持!,Spring WebFlux及VertX有相应的异步操作数据库的支持,但本框架没法集成。MyBatis之类的全是同步操作,小的应用系统没有问题,高并发系统的呑吐量就非常可怜了,这个大家可以测一下Spring MVC与WebFlux的性能对比。
软件技术日新月异,新一代的开发框架必定是异步的!对于作者来讲Spring还不够简单优雅,运行的也不够快,所以才会尝试重新造这个大轮子,争取让应用系统的开发人员有更多的时间关注数据结构、业务逻辑和用户体验,也争取让小伙伴们有一个丝般顺滑的开发体验。
边码代码边码文实属不易,作者需要您的支持请您多多点赞推荐!另欢迎感兴趣的小伙伴加入我们!
终于可以愉快的撸Java异步代码了!的更多相关文章
- Android--在Android应用中愉快地写C/C++代码(转)
1 前言 一直想在android层面写c进程,然后java可以与c进程交互,以前在android源码中想玩就可以直接在init.rc中加上交叉编译好的c进程就可以了,而在ide中,也就是ndk编译后各 ...
- FastDFS搭建及java整合代码【转】
FastDFS软件介绍 1.什么是FastDFS FastDFS是用C语言编写的一款开源的分布式文件系统.FastDFS为互联网量身定制,充分考虑了冗余备份.负载均衡.线性扩容等机制,并注重高可用.高 ...
- Java 异步处理简单实践
Java 异步处理简单实践 http://www.cnblogs.com/fangfan/p/4047932.html 同步与异步 通常同步意味着一个任务的某个处理过程会对多个线程在用串行化处理,而异 ...
- Paip.Php Java 异步编程。推模型与拉模型。响应式(Reactive)”编程FutureData总结... 1
Paip.Php Java 异步编程.推模型与拉模型.响应式(Reactive)"编程FutureData总结... 1.1.1 异步调用的实现以及角色(:调用者 提货单) F ...
- java异步编程降低延迟
目录 java异步编程降低延迟 一.ExecutorService和CompletionService 二.CompletableFuture(重要) 三.stream中的parallel(并行流) ...
- java 异步机制与同步机制的区别
所谓异步输入输出机制,是指在进行输入输出处理时,不必等到输入输出处理完毕才返回.所以异步的同义语是非阻塞(None Blocking). 网上有很多网友用很通俗的比喻 把同步和异步讲解的很透彻 转过 ...
- OS信号实现Java异步通知
OS信号实现Java异步通知本文将结合操作系统的信号机制,来尝试实现一个简单的,不依赖功能环境的Java异步通知功能.没有特殊说明,本文所有的示例,都是基于Linux.信号简介信号是在软件层次上对中断 ...
- Java 异步编程
昨天头儿给的学习文档我还没看完,头儿说:“MongoDB光会简单的添删改查什么的不行,要深入了解,你们连$set和$inc使用场景都分不清.” 确实,学习过一年多SQL,确实对学习MongoDB有点影 ...
- 如何编写优雅的异步代码 — CompletableFuture
前言 在我们的意识里,同步执行的程序都比较符合人们的思维方式,而异步的东西通常都不好处理.在异步计算的情况下,以回调表示的动作往往会分散在代码中,也可能相互嵌套在内部,如果需要处理其中一个步骤中可能发 ...
随机推荐
- linux修改文件所属的用户组以及用户
linux修改文件所属的用户组以及用户 将文件夹从A用户(huangxf)目录复制B用户(zhenglf)目录,其中B没有sudo权限.将A的Downloads文件夹下的所有文件,复制到B的Docum ...
- 将命令行提示符里的执行结果导出到text文件中
为便于查看和保存命令行提示符里的执行结果, 可以使用 ">" 将执行结果导入到指定.txt文件中. 例如: 在命令行提示符里查看C盘文件,并将结果导入到E盘dir-c-out ...
- 优化Windows电脑常见方法,提高速度,释放硬盘C盘
开始,我们首先让电脑变得易于使用一,提高开机速度常见的使电脑变卡的原因是:一台电脑同时安装了多个杀毒软件.一台电脑安装多个杀毒软件不仅占用你电脑大量内存.有时甚至会产生冲突,这会导致电脑运行非常缓慢, ...
- 自顶向下redis4.0(5)持久化
redis4.0的持久化 目录 redis4.0的持久化 简介 正文 rdb持久化 save命令 bgsave命令 rdb定期保存数据 进程结束保存数据 aof持久化 数据缓冲区 刷新数据到磁盘 ap ...
- react第十五单元(react路由的封装,以及路由数据的提取)
第十五单元(react路由的封装,以及路由数据的提取) #课程目标 熟悉react路由组件及路由传参,封装路由组件能够处理路由表 对多级路由能够实现封装通用路由传递逻辑,实现多级路由的递归传参 对复杂 ...
- [OI笔记]后缀自动机
本来没打算写的,不过想想看后缀自动机的理论看了两三天了才有点懂(我太傻了)-下周期末考的话大概要去复习一下文化课感觉回来又要忘得差不多,还是开篇blog记一下好了. 相关的资料: cls当年的课件:2 ...
- [日常摸鱼]bzoj2038[2009国家集训队]小Z的袜子-莫队算法
今天来学了下莫队-这题应该就是这个算法的出处了 一篇别人的blog:https://www.cnblogs.com/Paul-Guderian/p/6933799.html 题意:一个序列,$m$次询 ...
- Google、Facebook等均开始支持的HTTP3到底是个什么鬼?
GitHub 19k Star 的Java工程师成神之路,不来了解一下吗! 最近一段时间以来,关于HTTP/3的新闻有很多,越来越多的国际大公司已经开始使用HTTP/3了. 所以,HTTP/3已经是箭 ...
- Spring Cloud 2020.0.0 正式发布,全新颠覆性版本!
Spring Cloud 2020.0.0 没错,Spring Cloud 2020.0.0 正式发布了: 感谢Java技术栈群友通知,想入群的在公众号Java技术栈后台回复:wx,正在使用 Spri ...
- ASP.NET Core Web 支付功能接入 微信-扫码支付篇(转)
原文 https://www.cnblogs.com/essenroc/p/8630730.html // 随着版本更迭,新版本可能无法完全适用,请参考仓库内的示例. 这篇文章将介绍ASP.NET C ...