当前位置: 首页 > news >正文

[JavaScript]如何利用作用域块避免闭包内存泄漏?

出自《你不知道的JavaScript》上卷
以下是本书给出的反例:

function process (data) {...}
var bigdata={...}
process(bigdata);
var btn = document.getElementById('x');
btn.addEventListener('click', function click{...});

click会被回调在其他位置, 在addEventListener函数内作为闭包函数.
但其原作用域为全局,其会保留对原作用域的引用, 故全局作用域一直存活.
以下为本书给出的正例:

function process(data) {...}
{
    var bigdata = {}
    process(bigdata)
} ∥ 子作用域块会被回收
var btn = document.getElementById('x');
btn.addEventListener('click', function click(ev){..});

如此,使用显式创建的作用域块将需要回收的部分包裹,但注意不要将闭包函数需要使用的结构包裹进去,回收后会导致闭包函数无法正常工作…

以下放我自己写的示例:

function outside(){
    let data1=[];
    {
        const data0=[1,2,3,4,5];
        data1 = data0.filter(num){
            return num > 2;
        });
     }
    return function inside(){
        return data1;
    }
}
const a = outside()();
console.log(a);

注意要用let和const.
以上把闭包需要的data1留下,其他的哪怕是用于生产data1的结构都可以放到子作用域块回收.

相关文章:

  • Moonlight-16B-A3B: 变革性的高效大语言模型,凭借Muon优化器打破训练效率极限
  • DNS缓存使用中有什么问题?DNS缓存有哪些作用?
  • 蓝桥杯day2:解码异或 后的数组
  • test_cases测试用例层/test_1_login
  • ubuntu中的环境变量文件 bashrc、profile、environment简要总结
  • 【Java篇】一气化三清:类的实例化与封装的智慧之道
  • 口袋书签功能上新,免费使用
  • 网络华为HCIA+HCIP AAA原理与配置
  • 8.4《同一直线上二力的合成》
  • Linux下Redis哨兵集群模式搭建(1主2从+3哨兵)
  • Python实现WYY音乐下载
  • 机器学习快速入门教程
  • 设计模式工厂模式和单例模式结合
  • QwQ-32B 模型结构
  • 杰理科技JL703N双模蓝牙芯片—云信
  • 在node.js环境中使用web服务器http-server运行html静态文件
  • pytorch 笔记:张量索引的维度扩展规则
  • 【Linux】进程概念和进程状态
  • 单片机写的小液晶屏驱动+汉字滚屏
  • 天梯赛 L2-008 最长对称子串 (天梯赛常用string函数)
  • 摩天大楼天津117大厦复工背后:停工近十年,未知挑战和压力仍在
  • “人工智能是年轻的事业,也是年轻人的事业”,沪上高校师生畅谈感想
  • 北京动物园:大熊猫“萌兰”没有参加日本大阪世博会的计划
  • 金科服务:大股东博裕资本提出无条件强制性现金要约收购,总代价约17.86亿港元
  • 中公教育薪酬透视:董监高合计涨薪122万,员工精简近三成
  • 李公明|一周画记:哈佛打响第一枪