没有resolve及reject的Promise是否会造成内存泄露

正文

DevTools测试

可以用 DevTools 的 queryObjects()函数配合 setTimeout()来测试一下:

没有resolve及reject的Promise是否会造成内存泄露_第1张图片

没有resolve及reject的Promise是否会造成内存泄露_第2张图片

可以看到 1 万个 pending 的 promise 对象都不会被回收,直到 10 秒钟以后,再次执行queryObjects(Promise)

执行queryObjects(Promise)

没有resolve及reject的Promise是否会造成内存泄露_第3张图片

没有resolve及reject的Promise是否会造成内存泄露_第4张图片

那 1 万个 promise 对象是被回收了,但又多出一个 pending 的 promise 对象,可能是 DevTools 上执行命令的副作用。

测试事件回调

还可以测试一下通过事件回调来 resolve 的情况:

没有resolve及reject的Promise是否会造成内存泄露_第5张图片

没有resolve及reject的Promise是否会造成内存泄露_第6张图片

点击一下页面后,再次执行 queryObjects(Promise),居然已经 resolve 了的 1 万个 promise 对象还是没被回收,不懂了。

没有resolve及reject的Promise是否会造成内存泄露_第7张图片

没有resolve及reject的Promise是否会造成内存泄露_第8张图片

总之,queryObjects()可以遍历出 V8 堆上以某对象为原型的对象们,而且执行前会先做一次垃圾回收,学到这个就够了。

可疑的泄露对象

另外如果你真找到了可疑的泄露对象,却不知道被谁引用了,Safari 的 DevTools 刚刚实现了一个叫 queryHolders(target)的函数,它可以找到某个对象被哪些对象所引用了:

没有resolve及reject的Promise是否会造成内存泄露_第9张图片

没有resolve及reject的Promise是否会造成内存泄露_第10张图片

V8 的人看到了表示 V8 底层也支持这个功能,Chrome DevTools 上也可以加,估计很快就能实现了。

以上就是没有resolve及reject的Promise是否会造成内存泄露的详细内容,更多关于Promise内存泄露的资料请关注脚本之家其它相关文章!

你可能感兴趣的:(没有resolve及reject的Promise是否会造成内存泄露)