您现在的位置是:网站首页> 编程资料编程资料
没有resolve及reject的Promise是否会造成内存泄露_JavaScript_
2023-05-24
374人已围观
简介 没有resolve及reject的Promise是否会造成内存泄露_JavaScript_
正文
DevTools测试
可以用 DevTools 的 queryObjects()函数配合 setTimeout()来测试一下:


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


那 1 万个 promise 对象是被回收了,但又多出一个 pending 的 promise 对象,可能是 DevTools 上执行命令的副作用。
测试事件回调
还可以测试一下通过事件回调来 resolve 的情况:


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


总之,queryObjects()可以遍历出 V8 堆上以某对象为原型的对象们,而且执行前会先做一次垃圾回收,学到这个就够了。
可疑的泄露对象
另外如果你真找到了可疑的泄露对象,却不知道被谁引用了,Safari 的 DevTools 刚刚实现了一个叫 queryHolders(target)的函数,它可以找到某个对象被哪些对象所引用了:


V8 的人看到了表示 V8 底层也支持这个功能,Chrome DevTools 上也可以加,估计很快就能实现了。
以上就是没有resolve及reject的Promise是否会造成内存泄露的详细内容,更多关于Promise内存泄露的资料请关注其它相关文章!
相关内容
- vue3中关于路由hash与History的设置_vue.js_
- 详解如何让JavaScript代码不可断点_javascript技巧_
- vue混入mixin的介绍及理解_vue.js_
- 3分钟精通高阶前端随手写TS插件_JavaScript_
- JavaScript数组扁平转树形结构数据(Tree)的实现_javascript技巧_
- 使用vue+element ui实现走马灯切换预览表格数据_vue.js_
- 没有resolve及reject的Promise是否会造成内存泄露_JavaScript_
- vue3中关于路由hash与History的设置_vue.js_
- 详解如何让JavaScript代码不可断点_javascript技巧_
- 关于javascript中伪数组和真数组的一些小秘密_javascript技巧_
