码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2018-12-01 18:34:34      阅读:145      评论:0      收藏:0      [点我收藏+]

标签:.com   func   test   color   ror   var   完成   一个   技术分享   

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

再案例:

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‘); //date为文本内容
console.log(‘end sync read‘);    //同步读取结束

结果:

技术分享图片

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

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

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

调换一下代码就更明显了

var fs = require(‘fs‘);                //引入fs模块

console.log(‘start sync read‘); //同步读取开始
var date = fs.readFileSync(‘log.txt‘,‘utf-8‘); //date为读取的文本内容
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‘);    //异步读取结束
    }
});

结果:

技术分享图片

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

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

 

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

标签:.com   func   test   color   ror   var   完成   一个   技术分享   

原文地址:https://www.cnblogs.com/makai02323/p/10050229.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!