一个小技巧。首先打开最新版的chrome浏览器。
chrome能测试Javascript的内存堆(分配给js对象的内存)的状况,需要输入一段代码启动它:
chrome --enable-memory-info
接着,创建一个HTML文件,如下:
<script>
var i = 0;
setInterval(function(){
var before = window.performance.memory.usedJSHeapSize;
// Start
i = i + 10;
// End
var diff = window.performance.memory.usedJSHeapSize - before;
console.log(diff);
}, 100);
</script>
我现在的chrome版本是 31.0.1650.63。运行这个函数需要花9bytes,所以输出值减去了9。你可以根据你chrome的版本和设置改变这个数值。
如果运行这段脚本,注意到输入的数值为
2424 728 0 0 0 ...
第一个数字是因为V8引擎还在准备,过一会儿,js引擎将代码优化完,就能看到,结果不停的循环显示0。
接下来,在循环中放一段代码,看看会发生什么。如果在循环里初始化一个对象,如下:
setInterval(function(){
var before = window.performance.memory.usedJSHeapSize;
var obj = new Object();
var diff = window.performance.memory.usedJSHeapSize - before;
console.log(diff);
}, 100);
输出变为
3360 752 53 24 24 24 ...
可以总结出,分配24bytes给一个普通的Javascript对象。
可以使用此段代码来衡量你的代码循环会带来多少GC负荷。
使用Chrome测试JavaScript内存堆
本文介绍如何在最新版Chrome浏览器中启用内存信息功能,通过创建特定HTML文件并运行脚本来测试JavaScript内存堆的状况,了解内存使用情况及代码循环带来的GC负荷。
1040

被折叠的 条评论
为什么被折叠?



