postMessage webworker内存泄漏

时间:2015-10-19 21:18:32

标签: javascript memory-leaks web-worker postmessage transferable

我正在使用网络工作者以10毫秒的间隔传递一些数据。在任务管理器中,我可以看到工作内存集增加,直到我不取消间隔。

这就是我正在做的事情:

发送:

function send() {
 setInterval(function() { 
    const data = {
     array1: get100Arrays(),
     array2: get500Arrays()
    };

    let json = JSON.stringify( data );
    let arbfr = str2ab (json);
    worker.postMessage(arbfr, [arbfr]);
  }, 10);
}


function str2ab(str) {
   var buf = new ArrayBuffer(str.length*2); // 2 bytes for each char
   var bufView = new Uint16Array(buf);
   for (var i=0, strLen=str.length; i<strLen; i++) {
     bufView[i] = str.charCodeAt(i);
   }
   return buf;
 }

我也尝试过这样做,但没有成功:

// let json =  JSON.stringify( data );
// let arbfr = str2ab(json);
worker.postMessage(data);

任何人都知道为什么这可能会泄漏?我目前正在Chrome上试用此功能。

1 个答案:

答案 0 :(得分:1)

通常在主线程和工作线程之间多次传递值时会创建Web worker中的内存泄漏 如果可能,尝试仅将数组发送给Web worker一次 您还可以检测Transferable对象是否正常工作(阵列将被中断)

var ab = new ArrayBuffer(1);

try {
   worker.postMessage(ab, [ab]);

   if (ab.byteLength) {
      console.log('TRANSFERABLE OBJECTS are not supported in your browser!');
   } 
   else {
     console.log('USING TRANSFERABLE OBJECTS');
   }
} 
catch(e) {
  console.log('TRANSFERABLE OBJECTS are not supported in your browser!');
}