这才是缓存的正确打开?分享 1 段优质 JS 代码片段!

本内容首发于工粽号:程序员大澈,每日分享一段优质代码片段,欢迎关注和投稿!

大家好,我是大澈!

本文约 800+ 字,整篇阅读约需 1 分钟。

今天分享一段优质 JS 代码片段,使用 WeakMap 来缓存计算结果,以提高代码效率。

老规矩,先阅读代码片段并思考,再看代码解析再思考,最后评论区留下你的见解!

js 复制代码
const cache = new WeakMap();

function process(data) {
    if (!cache.has(data)) {
        const result = expensiveComputation(data);
        cache.set(data, result);
    }
    return cache.get(data);
}

function expensiveComputation(data) {
    // Simulate expensive computation
    return data * 2;
}

分享原因

这段代码展示了使用 WeakMap 进行缓存的一种实用方法。

通过这种方法可以有效地避免重复计算,提高性能,同时确保缓存对象在不使用时可以被垃圾回收。

项目中有 缓存计算结果、缓存DOM节点 这种场景时,可以考虑去使用。

代码解析

1. WeakMap 对象

WeakMap 是一种特殊类型的 Map,其键必须是对象,且这些对象是弱引用的。

如果没有其他引用指向这些对象,它们会被垃圾回收。这使得 WeakMap 非常适合用于缓存,因为不会阻止对象被垃圾回收。

弱引用是什么?

在计算机编程中,引用是一个对象被另一个对象或变量所指向的情况。

强引用:在程序运行期间,只要有一个强引用指向某个对象,该对象就不会被垃圾回收。例如,普通变量和属性引用。

弱引用:不会阻止垃圾回收。当只有弱引用指向一个对象时,如果没有其他强引用,该对象就会被垃圾回收。

没有其他引用指向这些对象,是什么意思?

这意味着该对象没有被任何强引用指向。

obj = null 即原始对象没有强引用,会被垃圾回收。

2. process 函数

检查 WeakMap 中是否已缓存 data 的计算结果。

如果没有缓存结果,则调用 expensiveComputation 进行计算,并将结果存储在 WeakMap 中。

最后,从 WeakMap 中获取并返回计算结果。

3. expensiveComputation 函数

模拟一个耗时的计算过程。在实际应用中,这个函数可以是任何复杂的计算逻辑。

  • end -
相关推荐
熊的猫40 分钟前
JS 中的类型 & 类型判断 & 类型转换
前端·javascript·vue.js·chrome·react.js·前端框架·node.js
mosen8681 小时前
Uniapp去除顶部导航栏-小程序、H5、APP适用
vue.js·微信小程序·小程序·uni-app·uniapp
别拿曾经看以后~2 小时前
【el-form】记一例好用的el-input输入框回车调接口和el-button按钮防重点击
javascript·vue.js·elementui
我要洋人死2 小时前
导航栏及下拉菜单的实现
前端·css·css3
川石课堂软件测试2 小时前
性能测试|docker容器下搭建JMeter+Grafana+Influxdb监控可视化平台
运维·javascript·深度学习·jmeter·docker·容器·grafana
JerryXZR3 小时前
前端开发中ES6的技术细节二
前端·javascript·es6
problc3 小时前
Flutter中文字体设置指南:打造个性化的应用体验
android·javascript·flutter
Gavin_9153 小时前
【JavaScript】模块化开发
前端·javascript·vue.js
懒大王爱吃狼4 小时前
Python教程:python枚举类定义和使用
开发语言·前端·javascript·python·python基础·python编程·python书籍
待磨的钝刨5 小时前
【格式化查看JSON文件】coco的json文件内容都在一行如何按照json格式查看
开发语言·javascript·json