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