这是写 t=null时的图
这是不写 t = null时的图
以上都是在无痕模式下6秒的结果
可以发现无论是否写t = null, 都是没发生内存泄漏的。
多次测试, 偶尔有以下结果
可以发现,有创建堆栈,但是是趋于稳定的,是绝对没发生内存泄漏的。
也许这就是v8的威力吧
以上测试是在遍历1w遍的情况下产生的。
再次根据次数测试
测试
1W
for (let i = 0; i < 10000; i++) {
t();
}
最终被释放, 且最高时占用1.6mb
100w
for (let i = 0; i < 1000000; i++) {
t();
}
最终被释放,且最高时占用2.8mb,最终heap为883kb
10000w
for (let i = 0; i < 100000000; i++) {
t();
}
最终被释放,且最高时占用还是2.8mb,最终heap为883kb
修改代码测试
将t的引用放入循环会怎样?
for (let i = 0; i < 100000000; i++) {
var t = test();
t();
}
可以看到确实比把引用写在外面多占用了很多内存,但最终还是平稳趋于2.0mb,所以并未造成内存飞升,只是t的引用没有释放.
手动将t引用释放!
for (let i = 0; i < 100000000; i++) {
var t = test();
t();
t = null
}
芜湖~ 起飞 heap又回到了883kb ~
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…