这是NodeJS的正确行为吗?

三角形

我使用获取了文件列表fs.readdir,并尝试读取前5个文件以读取其内容。

files.slice(0,5).forEach(function(item){
                        console.log(item);
                        readContent(path+"/"+item);
                    }
                );


function readContent(filename)
{
    var fs= require("fs");
    fs.readFile(filename, 'utf8', function(err, data)
    {
       console.log(data);
    });
}

但是它先打印文件名,然后只打印内容,而不是我期望的“文件名->内容”。我是NodeJS的新手,这是异步功能的一部分吗?还是我做错了什么?

28965131362770944.txt
28965131668946944.txt
28965131803168769.txt
28965131991912448.txt
28965132189040641.txt 

    <script type="text/javascript"> //<![CDATA[ window.location.replace('/#!/LovelyThang80/status/28965131362770944'); //]]> </script>
    <script type="text/javascript"> //<![CDATA[ (function(g){var c=g.location.href.split("#!");if(c[1]){g.location.replace(g.HBR = (c[0].replace(/\/*$/, "") + "/" + c[1].replace(/^\/*/, "")));}else return true})(window); //]]> </script>
    <script type="text/javascript" charset="utf-8">
      if (!twttr) {
        var twttr = {}
      }

      // Benchmarking load time.
      // twttr.timeTillReadyUnique = '1309338925-32926-11310';
      // twttr.timeTillReadyStart = new Date().getTime();
    </script>

        <script type="text/javascript"> //<![CDATA[ var page={};var onCondition=function(D,C,A,B){D=D;A=A?Math.min(A,5):5;B=B||100;if(D()){C()}else{if(A>1){setTimeout(function(){onCondition(D,C,A-1,B)},B)}}}; //]]> </script>
    <meta content="text/html; charset=utf-8" http-equiv="Content-Type" /> <meta content="en-us" http-equiv="Content-Language" /> <meta content="Chef salad is calling my name, I'm so hungry!" name="description" /> <meta content="no" http-equiv="imagetoolbar" /> <meta content="width = 780" name="viewport" /> <meta content="4FTTxY4uvo0RZTMQqIyhh18HsepyJOctQ+XTOu1zsfE=" name="verify-v1" /> <meta content="1" name="page" /> <meta content="NOODP" name="robots" /> <meta content="n" name="session-loggedin" /> <meta content="LovelyThang80" name="page-user-screen_name" />
    <title id="page_title">Twitter / Miss ImpressiveAngel: Chef salad is calling my n ...</title>
    <link href="http://a1.twimg.com/a/1309298903/images/twitter_57.png" rel="apple-touch-icon" /> <link href="/oexchange.xrd" rel="http://oexchange.org/spec/0.8/rel/related-target" type="application/xrd+xml" /> <link href="http://a3.twimg.com/a/1309298903/images/favicon.ico" rel="shortcut icon" type="image/x-icon" />

    <link href="http://a3.twimg.com/a/1309298903/stylesheets/twitter.css?1309198825" media="screen" rel="stylesheet" type="text/css" /> <lin
谢尔盖·沙法伦卡(Sergej Shafarenka)

是的,这是预期的行为。Node.js中的所有IO操作都是异步完成的。这意味着console.log(item)将立即执行,但是由于内容具有异步性,因此读取内容将在稍后发生。因此,主线程先打印所有文件名,然后打印其内容。

如果要打印“文件名内容”,“文件名内容”等顺序,则需要给该readContent()方法指定文件名,然后将其记录在readFile()方法中。像这样。

files.slice(0,5).forEach(function(item){
    readContent(path+"/"+item, item);
});

function readContent(filename, item) {
    var fs = require("fs");
    fs.readFile(filename, 'utf8', function(err, data) {
        console.log(item);
        console.log(data);
    });
}

PS有一个选项可以fs.readFileSync()同步读取文件。我强烈建议您不要在生产性代码中使用它,因为在读取文件时,它将停止处理其他传入请求。同步方法通常在应用程序初始化期间使用,但在应用程序为请求提供服务时,则永远不会在运行时使用。

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

这是模板的正确行为吗?

来自分类Dev

这是 Camel Spring DSL 中正确的日志记录行为吗?

来自分类Dev

这是预期的行为吗?

来自分类Dev

这是正确的缓存吗?

来自分类Dev

这是正确的做法吗?

来自分类Dev

这是TransactionEventHandler的正常行为吗?

来自分类Dev

这是正常的记忆行为吗?

来自分类Dev

这是不确定的行为吗?

来自分类Dev

这是TransactionEventHandler的正常行为吗?

来自分类Dev

这是正常的记忆行为吗?

来自分类Dev

chown -R user:user。*向后更改权限:这是正确的行为吗?

来自分类Dev

chown -R user:user。*向后更改权限:这是正确的行为吗?

来自分类Dev

这是正确的执行方式吗?

来自分类Dev

这是Moq的正确用法吗?

来自分类Dev

这是对sleep()的正确使用吗?

来自分类Dev

这是指令的正确用法吗?

来自分类Dev

这是正确的Numpy重塑吗?

来自分类Dev

这是Moq的正确用法吗?

来自分类Dev

BigQuery的性能:这是正确的吗?

来自分类Dev

这是TransactionSope的正确用法吗?

来自分类Dev

这是正确的 NFA 图吗?

来自分类常见问题

这是std :: ref行为逻辑上的吗?

来自分类Dev

这是Template Haskell的预期行为吗?

来自分类Dev

这是glGetTexParameterIuiv的错误或预期行为吗?

来自分类Dev

这是Powershell for循环的预期行为吗

来自分类Dev

这是Perl智能匹配的预期行为吗?

来自分类Dev

这种AdaBoost行为正确吗?

来自分类Dev

这是display:flex的正确用法吗?

来自分类Dev

这是计数多线程的正确方法吗?