大佬教程收集整理的这篇文章主要介绍了javascript – NodeJS和异步地狱,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
这就是我目前所拥有的:
var found = false; files.forEach(function(filE) { if (found) return false; fs.readFileSync(path + file,function(err,data) { if (err) return; found = true; conTinueWithstuff(); }); }); if (found === falsE) { // Handle this scenario. }
这是不好的.它阻塞(readFileSynC)因此它很慢.
我不能只为fs.readFile提供回调方法,它不是那么简单,因为我需要获取第一个找到的项目……并且可以以任意随机顺序调用回调.我认为一种方法是使用一个回调来增加一个计数器并保留一个找到/未找到信息的列表,当它到达files.length计数时,它会检查找到/未找到的信息并决定下一步做什么.
这很痛苦.我确实看到了事件IO的性能优势,但这是不可接受的.我有什么选择?
异步流控制的通用库是
https://github.com/caolan/async
async.filter(['file1','file2','file3'],path.exists,function(results){ // results now equals an array of the exisTing files });
如果你想说,避免额外调用path.exists,那么你可以很容易地编写一个“first”函数来执行操作,直到某些测试成功.与https://github.com/caolan/async#until类似 – 但您对输出感兴趣.
以上是大佬教程为你收集整理的javascript – NodeJS和异步地狱全部内容,希望文章能够帮你解决javascript – NodeJS和异步地狱所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。