午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

node.js - node垃圾回收、內存泄漏相關問題

瀏覽:255日期:2024-07-16 16:35:19

問題描述

最近剛開始研究垃圾回收,在試著回答餓了么大前端里的node內存釋放相關的問題時,遇到了一些疑問:

let arr = [];while(true) arr.push(1);

無限增加的數組,這肯定是會爆掉內存的。

let arr = [];while(true) arr.push();

這個我覺得只是一直使用 arr ,導致 arr 不能被釋放吧?

let arr = [];while(true) arr.push(new Buffer(1000));

這個是因為 Buffer 的大小小于8k,會先檢查內存池是否已滿,所以應該不會爆掉內存?

var theThing = null var replaceThing = function () { var originalThing = theThing var unused = function () { if (originalThing) console.log('hi') } theThing = { longStr: new Array(1000000).join(’*’), someMethod: function () { console.log(someMessage) } };};setInterval(replaceThing, 1000)

這個是因為 unused 對 originalThing 進行了引用,所以每一個 unused 都形成了一個 originalThing 的作用域 replaceThing 的閉包,這個閉包不會被回收掉,所以會在內存中一直累積?

因為自己不是很確定,所以麻煩懂的小伙伴回答一下,謝謝!

問題解答

回答1:

new Buffer估計不是簡單爆內存的問題,Buffer是分配在V8堆外的,所以實際上比第一個的問題還要嚴重,我剛才就直接死機了。

第二個應該說的是由于數組大小不會增長,所以不會爆內存。

第三個原文中就有提及原因

比如上述情況中 unused 的函數中持有了 originalThing 的引用, 使得每次舊的對象不會釋放從而導致內存泄漏

如果還是不理解可以看看原發現者的文章,里面講解的很詳細。

回答2:

死循環的代碼到哪都會爆內存,特別是js這種單線程語言,直接阻塞卡死。 Buffer類型我沒用過,會不會檢查內存池這個無法確定,但卡死了檢不檢查內存意義也不大。

最后一個我同意你的說法,每次循環都新建一個對象,theThing的引用地址不斷在變化,正常情況下舊的引用對象就應該被垃圾回收了,但由于unused引用了舊的對象originalThing,originalThing又一個私有變量,所以舊的對象無法被垃圾回收,就造成了內存泄露。

有沒有下面這段代碼的區別,環境chrome,運行30s。 第一幅圖是沒有這段代碼的結果,內存在15M浮動。第二幅圖是有這段代碼的結果,內存不斷增長。

function unused() { if (originalThing) console.log('hi');}

node.js - node垃圾回收、內存泄漏相關問題

node.js - node垃圾回收、內存泄漏相關問題

回答3:

我也不是很確定,不過可以用memwatch-next的包看看

相關文章:
主站蜘蛛池模板: 在线观看黄色片 | 婷婷综合在线观看 | 日本一区二区不卡 | 日本一级二级视频 | 亚洲自拍偷拍综合 | 中国黄色片视频 | 成人爱爱网站 | 天天操天天摸天天干 | 欧美久久久久久久久久 | 午夜无遮挡 | 天天射夜夜操 | 亚洲欧美第一页 | 少妇一级淫片免费放中国 | 欧美大喷水吹潮合集在线观看 | 2021亚洲天堂 | 国产wwwwww| 在线成人日韩 | 成人免费视频国产免费网站 | 久久久精彩视频 | 法国极品成人h版 | 国产精品一二区 | 神马久久av | 欧美精品午夜 | 毛片视频免费观看 | 性一交一乱一区二区洋洋av | 国产精品久久久久永久免费看 | 对白超刺激精彩粗话av | 精品性久久 | 亚洲图片自拍偷拍 | 国产精品探花一区二区在线观看 | 黄特一级姓交大片 | 国产成人精品综合久久久久99 | 一区二区三区在线播放 | 日本免费一区二区三区四区 | 久久精品午夜 | www欧美在线 | 香蕉在线网站 | 精品日韩一区二区三区 | av中文在线 | 国产日韩精品一区二区 | 999久久精品 |