亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

javascript - Node.js中輸出順序為什么和預期的不一樣呢?

瀏覽:87日期:2023-09-07 18:37:29

問題描述

考察下面的代碼,它用于用于輸出指定目錄下的文件

var fs=require(’fs’);function sleep(numberMillis) { //sleep方法,暫停numberMillis毫秒 var now = new Date(); var exitTime = now.getTime() + numberMillis; while (true) { now = new Date(); if (now.getTime() > exitTime) return; } }fs.readdir(__dirname,function(err,files){ //文件讀取方法 console.log(’’); if(!files.length){console.log(’找不到文件 n’); }else{console.log(’文件如下:’);function file(i){ var filename=files[i]; fs.stat(__dirname+’/’+filename,function(err,stat){if(stat.isDirectory()){ console.log(’ ’+i+’文件夾:’+filename+’/...’);}else{ console.log(’ ’+i+’文件:’+filename+’’);} }); i++; //sleep(1000); //。。。。。。。。######暫停1sif(i==files.length){console.log(’輸出完畢’); }else{file(i); //否則遞歸調用 }}file(0);//開始執行 }});

上述代碼輸出的結果我不能理解,按照這個程序設計的邏輯,應該先是把目錄下所有文件都列出來,然后計數器i==files.length后才輸出“輸出完畢”這個終結語。

javascript - Node.js中輸出順序為什么和預期的不一樣呢?javascript - Node.js中輸出順序為什么和預期的不一樣呢?

如上圖所示,不但“輸出完畢”這個終結語最先輸出,而且打印順序完全是錯亂的,多次運行的打印順序也不穩定。

我在想是不是異步調用有時間差,所以將上述代碼sleep(1000)注釋部分去掉,但是結果依然與我所預期不一致:“文件如下”提示語先輸出,此后停止1s后,后續語句幾乎同時出,沒有停頓,并且“輸出完畢”這個終結語依然第一個被打印

綜上所述,我想知道的是

為什么打印結果不穩定,為什么“輸出完畢”這個提示語首先被輸出?

為什么加上sleep(1000)這個暫停語句后,只有一開始停了1s,后面不再暫停而是同時輸出?

如何解決這個問題,即如何在修改盡可能少的情況下讓“輸出完畢”這個提示語最后輸出?

謝謝各位大佬賜教!

問題解答

回答1:

fs.stat是異步操作,所以你的輸出文件信息都是異步執行的,“輸出完畢”肯定先打印的。想同步可以用這個https://nodejs.org/docs/lates...

在sleep里加個console.log(’sleep’)看是不是 只輸出一次?

如果你想保證輸出文件信息之后才輸出“輸出完畢”,第一點里我提到的用fs.statSync估計修改比較少吧

回答2:

根據@Dont的回答,確實是異步方法調用的原因,因為fs.stat的回調函數是在事件輪詢中被調用,它一般在主程序運行間隙時候被調用,被調用時間和順序不定。使用statSync方法可以實現同步:

(function file(i){ var filename=files[i]; function read(stat){if(stat.isDirectory()){ console.log(’ ’+i+’ 033[36m 文件夾:’+filename+’/...033[39m’);}else{ console.log(’ ’+i+’ 033[36m 文件:’+filename+’033[39m’);} }; read(fs.statSync(__dirname+’/’+filename)); i++; ................

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 免费黄视频网站 | 国产高清小视频 | 亚洲视频在线免费看 | 亚洲第一免费 | 亚洲免费久久 | 亚洲国产成人va在线观看网址 | 韩国毛片免费看 | 网站大全黄免费 | 久久精品首页 | 国产精品麻豆 | 欧美黄色大片网站 | 久久国产亚洲精品麻豆 | avav国产| 国产精品久久久久久久午夜片 | 亚洲欧美h | 乡下女色又黄一级毛片 | 另类免费视频 | 能看av的网址 | 特级一级毛片免费看 | 国产成人午夜精品5599 | 成 人 免费观看网站 | 国产免费看网站v片不遮挡 国产免费高清 | 国产精品久久久久久久久久一区 | 亚洲一页 | 亚洲欧美视频一区二区三区 | 国产亚洲福利精品一区二区 | 亚洲精品区在线播放一区二区 | 一级毛片私人影院免费 | 亚洲一区二区三区四区 | 国产美女在线精品亚洲二区 | 国产欧美成人一区二区三区 | 国产精品第三页 | 久久精品国产2020观看福利色 | 天天拍拍天天爽免费视频 | 欧美一级性生活视频 | 欧美综合视频在线观看 | 222aaa免费| 国产在线观看网址你懂得 | xx免费| 国产伦精品一区二区三区无广告 | 国产日韩精品欧美一区喷 |