node 阻塞和非阻塞 同步和异步 讲解

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

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

阻塞和非阻塞,同步和异步是node.js里经常遇到的词汇,我举个简单的例子来说明:

我要看足球比赛,但是妈妈叫我烧水,电视机在客厅,烧水要在厨房。家里有2个水壶,一个是普通的水壶,另一个是水开了会叫的那种水壶。我可以:

用普通的水壶烧,人在边上看着,水开了再去看球。(同步,阻塞)这个是常规做法,但是我看球不爽了。
用普通水壶烧,人去看球,隔几分钟去厨房看看。(同步,非阻塞)这个又大问题,万一在我离开的几分钟水开了,我就麻烦了。
用会叫的水壶,人在边上看着。(异步,阻塞)这个没有问题,但是我太傻了。
用会叫的水壶,人去看球,听见水壶叫了再去看。(异步,非阻塞)这个应该是最好的。
等着看球的我:阻塞

看着电视的我:非阻塞

普通水壶:同步

会叫的水壶:异步

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


代码示例:
1.阻塞代码示例:
var fs = require("fs");

var data = fs.readFileSync('input.txt'); //fs方法读取文件内容
console.log(data.toString());
console.log("程序执行结束!");

当无法读取input.txt文件时整个代码块就会死锁,无法进行。

2.非阻塞代码示例:
var fs = require("fs");

fs.readFile('input.txt', function (err, data) {
    if (err) return console.error(err);  //出错时报错
    console.log(data.toString());
});
console.log("程序执行结束!");

当无法读取input.txt文件时依然会执行后边的代码

你可能感兴趣的:(node 阻塞和非阻塞 同步和异步 讲解)