异步编程
异步编程的优势和难点
曾经的单线程模型在同步 I / O 的影响下,由于 I / O 调用缓慢,应用层面 CPU 和 I / O 无法重叠进行。但是该模型符合编程人员的阅读思维习惯,因此同步 I / O 盛行了很多年。但是该模型存在性能问题,过去可以通过多线程的方式提升性能。但是从操作系统调度多线程的上下文切换开销,到实际编程里锁,同步等问题,让开发人员头疼的时候并不少。
优势
Node 带来的最大优势是基于事件驱动的非阻塞 I / O 模型。Node 通过事件循环的方式实现异步 I /O,javascript 线程负责分配任务和处理结果。I/ O 线程池里的线程完成分配的任务。所以可以保持整体的高效率。
难点
异常处理在编写异步方法时,只要将异常正确的传递给用户的回调方法即可,无需过多处理。
函数嵌套过深
阻塞代码
多线程编程
异步转同步
异步编程解决方案
事件发布/订阅模式
Promise/Deferred 模式
流程控制库
异步并发控制