Lodash源码阅读-isSafeInteger

功能概述

isSafeInteger 函数是 Lodash 中用于判断一个值是否为安全整数的工具函数。所谓安全整数,就是指在 JavaScript 中可以精确表示且不会失去精度的整数,它的范围是从 -(2^53 - 1) 到 2^53 - 1 之间的整数。

源码实现

js 复制代码
function isSafeInteger(value) {
  return (
    isInteger(value) && value >= -MAX_SAFE_INTEGER && value <= MAX_SAFE_INTEGER
  );
}

实现原理解析

整体思路

isSafeInteger 函数采用了一个三重检查的策略:首先确保值是整数,然后验证这个整数是否在安全范围内。这种实现方式既简单又可靠,能够准确识别出 JavaScript 中可以安全使用的整数值。

让我们详细分析每个判断条件:

1. isInteger(value) 检查

首先使用 isInteger 函数判断值是否为整数。这个检查可以过滤掉:

  • 非数字类型的值
  • 小数
  • NaN
  • Infinity/-Infinity
js 复制代码
isSafeInteger(3.14); // false(小数)
isSafeInteger("123"); // false(字符串)
isSafeInteger(NaN); // false(NaN)
isSafeInteger(Infinity); // false(无穷大)

2. value >= -MAX_SAFE_INTEGER 检查

确保数值不小于最小安全整数。JavaScript 中的 MAX_SAFE_INTEGER 是 2^53 - 1,所以最小安全整数是它的负值。

js 复制代码
isSafeInteger(-9007199254740991); // true(最小安全整数)
isSafeInteger(-9007199254740992); // false(超出最小安全范围)
isSafeInteger(Number.MIN_SAFE_INTEGER); // true(同最小安全整数)

3. value <= MAX_SAFE_INTEGER 检查

确保数值不大于最大安全整数。这个检查可以过滤掉那些虽然是整数,但已经超出了 JavaScript 能够精确表示的范围的数值。

js 复制代码
isSafeInteger(9007199254740991); // true(最大安全整数)
isSafeInteger(9007199254740992); // false(超出最大安全范围)
isSafeInteger(Number.MAX_SAFE_INTEGER); // true(同最大安全整数)

总结

isSafeInteger 函数通过组合整数检查和范围验证,提供了一个可靠的方式来判断一个数值是否为安全整数。它的实现简单直观,但却能有效地帮助我们避免在处理大数时可能出现的精度问题。

相关推荐
sbjdhjd15 小时前
Redis 主从复制、哨兵高可用与 Cluster 集群部署实验手册
运维·前端·redis·云原生·开源·bootstrap·html
乐兮创想 小林16 小时前
企业官网移动端性能优化实战:从 Core Web Vitals 到图片/CDN/响应式的工程清单
前端·性能优化·网站建设·北京网站建设公司
疯狂SQL16 小时前
JWT 在线解码、验签、生成一篇讲透:附前端实现、工具架构与在线体验地址
javascript·jwt·编解码·jwt测试
前端一小卒16 小时前
不手写代码的第 30 天,我才明白前端这个岗位还剩什么
前端·javascript·ai编程
Ajie'Blog16 小时前
Copilot Agent Tasks API 开放:AI 编程开始进入后台任务时代
服务器·前端·javascript·人工智能·copilot·ai编程
老毛肚17 小时前
jeecgboot vue TS & 模板化 04
前端·javascript·vue.js
晓131317 小时前
【Cocos Creator 2.x】篇——第二章 入门
javascript·游戏引擎
AI_零食18 小时前
鸿蒙PC Electron跨平台应用开发:24时区时间表应用详解
前端·华为·electron·开源·harmonyos·鸿蒙
Electrolux19 小时前
[onlyoffice-v9]纯前端怎么实现编辑预览office
前端·javascript·github
VidDown19 小时前
Webhook 调试器:让第三方回调“原形毕露”
java·开发语言·javascript·编辑器·postman