Map.prototype.has()仅判断键是否存在,即使值为undefined也返回true;delete()彻底移除键值对,而set(key, undefined)仍保留键;clear()批量清空性能远优于循环delete()。Map.prototype.has() 判断键是否存在,但不等于值不为 undefined很多人误以为 has() 是在检查「这个键对应的值是不是有效」,其实它只关心键本身是否被显式设置过。哪怕你执行过 map.set('k', undefined),has('k') 依然返回 true。常见错误现象:用 if (map.get('x') !== undefined) 替代 has('x'),结果漏掉显式存了 undefined 的情况;或者反过来,用 has() 去判断值是否「有业务意义」,导致逻辑错判。判断键是否存在(比如做缓存命中检测),优先用 has()判断值是否「非空/有效」(如非 null、非 undefined、非空字符串),必须用 get() + 显式比较has() 性能略优于 get(),因为它不读取值,只查哈希表结构delete() 删除键后,get() 返回 undefined,但 has() 返回 falsedelete() 是唯一能真正从 Map 中移除键值对的操作。它和对象的 delete obj.key 不同------Map 的 delete() 是方法调用,且返回布尔值表示是否删除成功。使用场景:需要彻底清理缓存项、释放引用避免内存泄漏、或实现 LRU 等需精确控制键生命周期的逻辑。map.delete('k') 成功删除返回 true,删不存在的键返回 false删完再调 get('k') 得 undefined,has('k') 得 false,二者行为一致别用 map.set('k', undefined) 代替 delete():键还在,遍历仍会出现,内存也没释放注意兼容性:Map.prototype.delete() 在 IE 完全不支持,Node.js 0.12+ 起可用has() 和 delete() 都不能替代 clear() 批量清空想清空整个 Map?别循环调 delete(),也别靠 has() 判断后跳过------直接上 clear()。 WisPaper 复旦大学研发的AI学术搜索工具,5分钟内筛选1000篇论文
相关推荐
WL_Aurora9 分钟前
Python 算法基础篇之集合treesforest15 分钟前
IP精准定位服务:从城市轮廓到街道坐标,技术如何重塑空间感知大明者省18 分钟前
宝塔开了端口,Ubuntu 还得开相应端口才能打通头歌实践平台28 分钟前
招聘大数据可视化Teable任意门互动1 小时前
AI原生开源多维表格有哪些?主流开源多维表格对比解析Cloud_Shy6181 小时前
Python 数据分析基础入门:《Excel Python:飞速搞定数据分析与处理》学习笔记系列(第八章 使用读写包操作 Excel 文件 上篇)TDengine (老段)2 小时前
MNode 内部机制深度解析 — SDB、事务引擎与 DDL 处理全链路这个DBA有点耶2 小时前
数据库上云 vs 自建:从成本到人力的三维对比与决策框架shizhan_cloud2 小时前
MySQL 索引优化 + 慢查询日志輕華2 小时前
uv工具详解——Python包与项目管理器完全指南