【node】同步读取readFileSync和异步读取readFile的区别案例

先结论:异步读取文件的时候由操作系统在后台进行读取,不会阻碍下面的代码执行。同步读取的时候会阻碍下面的代码执行。

再案例:

test.js

var fs = require('fs');                //获取fs模块
console.log('start async read');        //异步读取开始
fs.readFile('test2.js',function(error,date){    //读取文件,回调函数第一个参数表示错误信息,第二个参数为读取的文本内容
    if(error){
        console.log(error);
    }else{
        console.log('end async read');    //异步读取结束
    }
});


console.log('start sync read'); //同步读取开始
var date = fs.readFileSync('log.txt','utf-8');
console.log('end sync read');    //同步读取结束

结果:

看出是按这个顺序执行的:异步读取开始--------------->同步读取开始--------------------->同步读取结束---------------->异步读取结束

异步读取没有结束,同步读取就完成了。

结论:异步读取没有阻塞下面代码的执行。

 

调换一下代码就更明显了

var fs = require('fs');                //获取fs模块

console.log('start sync read'); //同步读取开始
var date = fs.readFileSync('log.txt','utf-8');
console.log('end sync read');    //同步读取结束


console.log('start async read');        //异步读取开始
fs.readFile('test2.js',function(error,date){    //读取文件,回调函数第一个参数表示错误信息,第二个参数为读取的文本内容
    if(error){
        console.log(error);
    }else{
        console.log('end async read');    //异步读取结束
    }
});

结果:

看出是按这个顺序执行的:同步读取开始--------------->同步读取结束--------------------->异步读取开始---------------->异步读取结束

结论:同步读取阻塞下面代码执行。

 

posted @ 2017-07-19 15:56  你大斌哥  阅读(34561)  评论(0编辑  收藏  举报