Node.JS中回调嵌套和async/await执行空函数性能效率对比测试


发布者 ourjs  发布时间 1582204022881
关键字 Node.JS  C 

asyn/await关键字可以让原来的回调嵌套和链式写法,改造成同步语法。util.promisify可以很方便地将回调函数Promise化,那么Promise函数的async/await执行和回调函数的嵌套执行或链式执行在性能上有差异吗?

下面我们会写一个测试用例,用两种方式执行一个空函数4400次,比较执行时间。

 Node.JS 对非异步函数的嵌套层数有限制,否则会报出:Maximum call stack size exceeded 错误,所以设置4400次。

var util = require('util')
var count = 4400

var testCallback = function() {

var next = function(cb) {
//TODO

cb && cb()
}

var curr = 0
var time = Date.now()
var isEnd = function() {
if (curr++ > count) {
console.log('callback done', Date.now() - time)
return
}

next(isEnd)
}

isEnd()
}

var testCallback2 = function() {
var curr = 0
var time = Date.now()
var next = function() {
if (curr++ > count) {
console.log('callback done', Date.now() - time)
return
}

//TODO

next()
}

next()
}

var testAsync = async function() {
var next = function(cb) {
//TODO

cb && cb()
}

var nextAsync = util.promisify(next)

var time = Date.now()
for (var i = 0; i < count; i++) {
await nextAsync()
}
console.log('async done', Date.now() - time)
}

testCallback()
testCallback2()
testAsync()

 

执行测试文件,测试环境是 node v12.15.0。

$ node testPerformance.js
callback done 1
callback done 0
async done 13

 

可以看到,按顺序执行同一个空函数4千次,用时为0~1,即在1毫秒内完成。
用async/await方式执行,用时12~14毫秒之间。

不过如果只执行一次,对性能的影响微乎其微。不过在高并发场所,回调函数的性能要优于async/await









 热门文章 - 分享最多
  1. OnceDB:使用Redis全文字符串模糊搜索,多条件查询,创建索引搜索等使用帮助教程
  2. 用旺司OnceOA免费搭建企业多人知识文档管理协作办公软件
  3. node.js将回调函数嵌套,用promise改造成async/await顺序执行:异常处理和返回多个参数
  4. Node.JS如何按顺序调用async函数,如何判断是否为async函数,在mocha中自动化测试async/await代码
  5. 基于Node.JS和Electron编写的集成开发环境 VS Code,成为最受欢迎的IDE
  6. 使用node.js和oAuth2协议集成Github/LinkedIn第三方登录以OnceOA模块源码为例
  7. Redis源码分析,在C语言中将当前时间转化成毫秒微秒整数值
  8. JavaScript在Array数组中按指定位置删除或添加元素对象
  9. Node.JS发送http请求批量检查文件中的网页地址、服务是否有效可用
  10. Linux下的tar压缩解压缩命令详解,创建解压目录到.tar.gz包

 相关阅读
  1. Node.JS的竞争对手?QuickJS入门教程,使用os模块读写文件,并将JavaScript编绎成可执行文件
  2. Node.JS用RSA签名算法公钥加密私钥解密,实现License软件授权验证
  3. Node.JS借助OS模块获取当前Windows系统用户登录名
  4. Node.JS在命令行中检查Chrome浏览器是否安装,并打开指定网址
  5. node.js中将console.log日志内容输出到文件
  6. 使用Node.JS批量查找替换目录下文本文件中图片地址内容
  7. 判断Node.JS TCP Socket当前连接状态
  8. Node.JS进程间通讯的几种方法:Redis Publish/Subscribe 和 UDP Socket
  9. Node.JS命令行或批处理中更改Linux用户密码
  10. Node.JS用Path将相对路径转为绝对路径

  开源的 OurJS
OurJS开源博客已经迁移到 OnceOA 平台。

  关注我们
扫一扫即可关注我们:
OnceJS

OnceOA