[Javascript Performance] How to benchmark code performance
Code:
benchmark.js
const { performance } = require('perf_hooks');
// SETUP 🏁
let iterations = 1e7;
const a = 1;
const b = 2;
const add = (x, y) => x + y;
// 🔚 SETUP
performance.mark('start');
// EXERCISE 💪
while (iterations--) {
add(a, b);
}
// 🔚 EXERCISE
performance.mark('end');
performance.measure('My Special Benchmark', 'start', 'end');
const [ measure ] = performance.getEntriesByName('My Special Benchmark');
console.log(measure);
Running in Node:
node --trace-opt benchmark.js
Running in Chrome:
Record performance
Why V8 engine can optimze this code:
const add = (x, y) => x + y;
Because it is simple, rerun multip times, after first time, interportor can guess that it will accpet numbers as params. So it can skip many functions for checking & parsing
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2021-12-03 [AWS] Using EC2 Roles and Instance Profiles in AWS
2019-12-03 [Algorithm] 122. Best Time to Buy and Sell Stock II
2019-12-03 [ARIA] Create an Accessible Tooltip on a Text Input
2019-12-03 [Algorithm] 121. Best Time to Buy and Sell Stock
2019-12-03 [Go] Filter an Array in Go
2019-12-03 [GO] Remove Elements from a slice in Go
2019-12-03 [Go] Iterate over an Array or Slice in Go