浅谈 node.js的阻塞和非阻塞

  • Post author:
  • Post category:其他


1.阻塞:就像单线程cpu一样,一个任务由多个小任务组成,但是只能一个任务接一个任务流程的往想下走,谁在任务排序的前面就谁先执行,执行完了进行下一个,如果遇到错误,下面的小任务就不要做了,一直卡住。

2.非阻塞:就像多线程cpu一样,一个任务由多个小任务组成,可以分开线程来做,哪个线程做分配到的任务,完成了对应的任务就行,某个线程的任务没做完那就做报对应的错,其他的不受影响。

举个例子:

我要看电视,但是妈妈叫我煮稀饭,电脑在卧室,电饭锅在厨房 ,家里有两个电饭锅,一个普通锅一个智能电饭锅。

  1. 用普通的电饭锅煮,人在边上看着,煮好了再去看电视。

    (阻塞/同步)

    这个是常规做法,但是我看电视错过了。
  2. 用普通电饭锅煮,人去看电视,隔几分钟去厨房看看。

    (非阻塞/同步)

    这个又大问题,万一在我离开的几分钟饭煮成了干饭,我就麻烦了。
  3. 用智能的电饭锅,人在边上看着。

    (异步/阻塞)

    这个没有问题,但是我太傻了。
  4. 用智能的电饭锅,人去看电视,听见智能电饭锅提示了再去看。

    (异步/非阻塞)

    这个应该是最好的。

等着看电视的我:阻塞

看着电视的我:非阻塞

普通电饭锅:同步

智能的电饭锅:异步

所以,异步往往配合非阻塞,才能发挥出威力。



版权声明:本文为dear_hang原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。