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

第二章 营销型网站建设测验智推教育seo课程

第二章 营销型网站建设测验,智推教育seo课程,新房装修,wordpress采集阿里妈妈ES12 (ECMAScript 2021) 特性总结:WeakRef 1. WeakRef 概述 描述 WeakRef 是 ES12 引入的一个新特性,用于创建对对象的弱引用。弱引用不会阻止垃圾回收器回收对象,即使该对象仍然被弱引用持有。WeakRef 通常与 FinalizationRegistry 结合使…

ES12 (ECMAScript 2021) 特性总结:WeakRef

1. WeakRef 概述

描述

WeakRef 是 ES12 引入的一个新特性,用于创建对对象的弱引用。弱引用不会阻止垃圾回收器回收对象,即使该对象仍然被弱引用持有。WeakRef 通常与 FinalizationRegistry 结合使用,用于在对象被垃圾回收时执行清理操作。

语法

const weakRef = new WeakRef(targetObject);

主要方法

  • deref():返回弱引用指向的目标对象。如果目标对象已被垃圾回收,则返回 undefined

2. WeakRef 的用法

创建弱引用

const obj = { name: "Alice" };
const weakRef = new WeakRef(obj);// 访问目标对象
const target = weakRef.deref();
console.log(target); // { name: "Alice" }

检查对象是否被回收

let obj = { name: "Bob" };
const weakRef = new WeakRef(obj);// 解除对 obj 的强引用
obj = null;// 强制触发垃圾回收(仅用于演示,实际环境中不应手动调用)
global.gc();// 检查对象是否被回收
setTimeout(() => {const target = weakRef.deref();console.log(target); // undefined(对象已被回收)
}, 1000);

3. WeakRef 的使用场景

1. 缓存系统

在缓存系统中,可以使用 WeakRef 来缓存对象。当内存不足时,垃圾回收器会自动回收这些对象,从而避免内存泄漏。

示例
const cache = new Map();function getCachedData(key) {let cachedRef = cache.get(key);if (cachedRef) {const cachedData = cachedRef.deref();if (cachedData) {return cachedData;}}// 重新获取数据并缓存const newData = fetchData(key);cache.set(key, new WeakRef(newData));return newData;
}

2. 监听对象生命周期

结合 FinalizationRegistry,可以在对象被垃圾回收时执行清理操作。

示例
const registry = new FinalizationRegistry((heldValue) => {console.log(`Object with value ${heldValue} has been garbage collected.`);
});let obj = { name: "Charlie" };
const weakRef = new WeakRef(obj);// 注册清理回调
registry.register(obj, "some metadata");// 解除对 obj 的强引用
obj = null;// 当 obj 被垃圾回收时,会触发清理回调

3. 避免内存泄漏

在需要持有对象引用但又不想阻止垃圾回收的场景中,WeakRef 是一个理想的选择。

示例
class EventListener {constructor(target) {this.targetRef = new WeakRef(target);this.handleEvent = this.handleEvent.bind(this);target.addEventListener("click", this.handleEvent);}handleEvent(event) {const target = this.targetRef.deref();if (target) {console.log("Event triggered on:", target);} else {// 目标对象已被回收,清理事件监听器event.currentTarget.removeEventListener("click", this.handleEvent);}}
}

4. 注意事项

  1. 垃圾回收的不确定性

    • 垃圾回收的时机由 JavaScript 引擎决定,无法手动控制。
    • 即使对象不再被强引用,垃圾回收也可能不会立即执行。
  2. 避免滥用

    • WeakRefFinalizationRegistry 是高级特性,通常只在特定场景下使用。
    • 过度使用可能导致代码难以理解和维护。
  3. 兼容性

    • 确保目标运行环境支持 WeakRefFinalizationRegistry

5. 总结

特性描述使用场景
WeakRef创建对对象的弱引用,不会阻止垃圾回收器回收对象缓存系统、监听对象生命周期、避免内存泄漏
deref()返回弱引用指向的目标对象,若对象已被回收则返回 undefined检查对象是否仍然可用
结合 FinalizationRegistry在对象被垃圾回收时执行清理操作对象生命周期管理、资源清理

http://www.dtcms.com/wzjs/230236.html

相关文章:

  • 网站添加搜索关键字优化大师的功能有哪些
  • 亿玫网站建设班级优化大师使用指南
  • 大学生做企业网站谷歌推广教程
  • 做渔家乐推广的有哪些好网站2022最新引流推广平台
  • 义乌建设局网站域名搜索引擎
  • 做付费视频网站免费站推广网站2022
  • 河南平台网站建设设计百度竞价托管费用
  • 买的服务器做两个网站月嫂免费政府培训中心
  • 鬼畜做的青龙游戏网站宁波网络推广平台
  • 做二维码推送网站cpc广告点击日结联盟
  • 网站建设 的介绍数字营销成功案例
  • 张家港外贸型网站建设快速收录网
  • wap 网站的盗链问题免费海报模板网站
  • 快要到期的域名网站网络营销服务
  • wordpress mu调取厦门seo专业培训学校
  • 网站建设的简历制作logo设计
  • 网站运营推广方案设计百度关键词排名怎么靠前
  • 多语言网站开发设计百家号官网
  • crm系统哪种品牌的好搜索引擎优化百度百科
  • 深圳网站建设服务清单网站优化公司哪个好
  • 虚拟机做网站服务sem竞价推广代运营收费
  • 成都网站建设求职简历软文发布平台媒体
  • 北京网站制作建设公司哪家好百度客户端电脑版
  • 公司做企业网站百度软文推广怎样收费
  • 网站策划和网站制作云seo关键词排名优化软件
  • 图书馆 网站建设推广宣传方式有哪些
  • 品牌宣传片策划公司同仁seo排名优化培训
  • wordpress数据库损坏网站软文推广做的比较好的推广平台
  • 网站设计与开发培训班电商数据统计网站
  • 安阳网站建设哪家正规口红的推广软文