深入浅出Node.js - 异步编程

异步编程

异步编程的优势和难点

曾经的单线程模型在同步I/O的影响下,由于I/O调用缓慢,应用层面CPU和I/O无法重叠进行。但是该模型符合编程人员的阅读思维习惯,因此同步I/O盛行了很多年。但是该模型存在性能问题,过去可以通过多线程的方式提升性能。但是从操作系统调度多线程的上下文切换开销,到实际编程里锁,同步等问题,让开发人员头疼的时候并不少。

优势

Node带来的最大优势是基于事件驱动的非阻塞I/O模型。Node通过事件循环的方式实现异步I/O,javascript线程负责分配任务和处理结果。I/O线程池里的线程完成分配的任务。所以可以保持整体的高效率。

难点

  1. 异常处理
    在编写异步方法时,只要将异常正确的传递给用户的回调方法即可,无需过多处理。
  2. 函数嵌套过深
  3. 阻塞代码
  4. 多线程编程
  5. 异步转同步

异步编程解决方案

  1. 事件发布/订阅模式
  2. Promise/Deferred模式
  3. 流程控制库

异步并发控制

    原文作者:HPJL
    原文地址: https://segmentfault.com/a/1190000017451556
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞