异步操作的使用场景

Posted gdpw

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了异步操作的使用场景相关的知识,希望对你有一定的参考价值。

在看MVC示例工程看到有一些action使用了async action异步方法,但并不是所有actio都是异步的,我查阅了一些资料,总结了异步操作的使用场景,如有错误,请不吝赐教。

我们采用异步的方式来处理这样的耗时请求,工作线程可以让后台线程来接手,自己可以及时地被释放到线程池中用于进行后续请求的处理,从而提高了整个服务器的吞吐能力。值得一提的是,异步操作主要用于I/O绑定操作(比如数据库访问和远程服务调用等),而非CPU绑定操作,因为异步操作对整体性能的提升来源于:当I/O设备在处理某个任务的时候,CPU可以释放出来处理另一个任务。如果耗时操作主要依赖于本机CPU的运算,采用异步方法反而会因为线程调度和线程上下文的切换而影响整体的性能。
IO操作:磁盘数据的读写。包括文件读写(字节流,缓冲区等)、网络请求(基于socket的请求、比如数据库连接,第三方服务API调用)。
cpu操作:系统计算。
示例场景: 数据轮训,登录注册


以上是关于异步操作的使用场景的主要内容,如果未能解决你的问题,请参考以下文章

同步异步的使用场景及好处

分布式架构中异步的使用场景

牛逼啊!异步神器:CompletableFuture实现原理和使用场景

TaskCompletionSource的使用场景

聊一聊Promise

最适合使用RxJava处理的四种场景