JavaScript中for循环的内存使用情况

6

我尝试在nodejs(0.10.35)中分析内存使用情况,我创建了以下两个文件,并用node --expose-gc运行:

var a和var b被初始化为空字符串

运行for循环以使a和b变得更大

setInterval每隔1秒打印出内存使用情况

x >> 20运算符相当于Math.floor(x/1024/1024),将结果转换为MB单位

//file 1.js

var a = '', b = '', n = 0;
var i = 10000000; for (;i;i--) {a += i; b += i;}}

setInterval(function(){
    var m = process.memoryUsage();
    console.log(++n,m.rss>>20,m.heapTotal>>20,m.heapUsed>>20);  
},1000);

setTimeout(function(){  
    global.gc();
    console.log('1st garbage collect');
},2500);

setTimeout(function(){
    a = null;
    console.log('var a cleared');   
},5000);

setTimeout(function(){
    global.gc();
    console.log('2nd garbage collect');
},7500);

//file 2.js is similar to file 1 except that var a and var b are changed at separate loops
var i = 10000000; for (;i;i--) {a += i;}
var i = 10000000; for (;i;i--) {b += i;}

我从控制台获取了结果。
     1.js                  2.js
1    1098 1073 1069        1407 1378 1375
2    1098 1073 1069        1407 1378 1375
     1st garbage collect
3    1098 1073 1069        715 696 688
4    1098 1073 1069        715 696 688
     var a cleared
5    1098 1073 1069        715 696 688
6    1098 1073 1069        715 696 688
7    1098 1073 1069        715 696 688
     2nd garbage collect
8    19   11   1           20  12  1

我的问题是:

  1. a.length和b.length只有约65 MB,为什么文件1.js的内存使用量达到了1000 MB左右,而文件2.js的内存使用量达到了1400 MB左右?
  2. 在第一次垃圾回收之后,变量b不应该被回收吗?但是文件1.js的内存使用量仍然大于1000 MB,而文件2.js的内存使用量却只有约700 MB?

在第二次垃圾回收之后,内存降至少于20 MB,正如预期的那样。我这里是否有什么看错的地方?


兄弟,你现在能解释一下这个吗? - yusung lee
1个回答

0

你有两个大括号

var i = 10000000; for (;i;i--) {a += i; b += i;}}//<-----here

也许这就是为什么函数表现不正常的原因。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接