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

ps做的网站在线设计装修的网站

ps做的网站,在线设计装修的网站,长春网站推广方式,网站建设服务内容问题本质 JavaScript 使用 IEEE 754 双精度浮点数标准存储所有数字(包括整数和小数)。这种格式将数字表示为二进制分数,导致某些十进制小数无法精确表示(类似1/3在十进制中无法精确表示)。核心问题在于: …

问题本质

JavaScript 使用 IEEE 754 双精度浮点数标准存储所有数字(包括整数和小数)。这种格式将数字表示为二进制分数,导致某些十进制小数无法精确表示(类似1/3在十进制中无法精确表示)。核心问题在于:

  1. 二进制表示限制
    • 0.1 的二进制表示:0.00011001100110011…(无限循环)
    • 0.2 的二进制表示:0.0011001100110011…(无限循环)
    • 64位存储空间必须截断这些无限循环,导致精度丢失
  2. 典型问题表现
0.1 + 0.2 === 0.3; // false
console.log(0.1 + 0.2); // 0.30000000000000004

问题根源详解

  1. 存储结构限制
    • 64位空间分配:
      • 1位符号位
      • 11位指数位
      • 52位尾数位(实际精度限制来源)
    • 能精确表示的整数范围:-2⁵³ 到 2⁵³(约 ±9e15)
  2. 小数精度问题
    • 十进制小数转二进制时,分母需是2的幂(如0.5=1/2,0.25=1/4)
    • 0.1(1/10)和0.2(1/5)的分母不是2的幂,导致无限循环二进制表示
  3. 误差传播规律
    • 加减法:误差可能放大或缩小
    • 乘除法:误差呈倍数增长
    • 连续运算:误差会累积放大

影响场景

  1. 金融计算:
    • 利息计算:0.075 * 100 = 7.500000000000001
    • 货币累加:10.01 + 20.02 = 30.029999999999998
  2. 科学计算:
    • 物理模拟中的微小误差累积
    • 工程计算的精度要求(如航天、建筑)
  3. 条件判断:
// 危险的相等判断
const total = 0.1 + 0.2;
if (total === 0.3) { // 永远不会执行// 关键业务逻辑
}

四大解决方案

  1. 整数运算法(推荐)
    原理:将小数转换为整数计算后再转换回小数
// 处理金额(两位小数)
function moneyAdd(a, b) {return (a * 100 + b * 100) / 100;
}
moneyAdd(0.1, 0.2); // 0.3
适用场景:
固定小数位的场景(货币、百分比)
性能要求高的场景
  1. 精度控制法
    原理:使用toFixed()控制显示精度
const result = (0.1 + 0.2).toFixed(2); // "0.30"
注意事项:
返回字符串类型,需用parseFloat()转换
本质是四舍五入,非精确计算
银行家舍入规则(IEEE 754标准)
  1. 容差比较法
    原理:使用极小容差值(epsilon)进行比较
function floatEqual(a, b) {return Math.abs(a - b) < Number.EPSILON * Math.pow(2, 2);
}
floatEqual(0.1 + 0.2, 0.3); // true
关键点:
Number.EPSILON表示1与大于1的最小浮点数的差值(约2.22e-16)
容差阈值应根据实际业务需求调整
  1. 专用库解法(最可靠)
    原理:使用高精度数学库处理计算
// 使用decimal.js
const Decimal = require('decimal.js');
const sum = new Decimal(0.1).plus(0.2);
console.log(sum.toString()); // "0.3"
推荐库:
decimal.js:任意精度十进制算术
big.js:轻量级库
bignumber.js:支持配置精度和舍入模式

最佳实践指南

  1. 关键系统原则
    • 金融系统:始终使用整数运算(按分存储)
    • 科学计算:优先选用decimal.js等专业库
  2. 避免操作
// 危险操作
0.3 - 0.1 // 0.19999999999999998
0.15 * 10 // 1.4999999999999998// 安全替代
(0.3 * 10 - 0.1 * 10) / 10 // 0.2
  1. 比较策略
    • 避免直接===比较浮点数
    • 使用容差范围比较
    • 将浮点数转换为整数后再比较

现实启示

JavaScript的精度问题不是语言缺陷,而是计算机科学中精度与效率的经典权衡。

http://www.dtcms.com/a/462874.html

相关文章:

  • Python-UV环境管理实战
  • 江门建设建筑网站一个人做网站难吗
  • 网站开发使用哪些开发语言长沙的网站建设
  • 光效网站制作网站副本
  • 网站推广经典案例网站优化关键词排名自己怎么做
  • 电子商务网站建设实验原理集约化网站群建设
  • RocketMQ如何使用Netty
  • 哪个网站可以做片头深圳小程序建设公司
  • 腾讯开始数字人mousetalk 部署笔记
  • 做影视网站侵权吗免费刷推广链接的网站
  • 悠悠我心的个人网站怎么做网站侧边栏怎么做
  • 基于机器学习方法的网球比赛胜负趋势预测
  • 金华职院优质校建设网站网站设置在设备之间共享什么意思
  • Day 09(上) B2a实例分析-----如何理解Sensitive detector 和 Hit
  • h5网站需要哪些技术欧模网室内设计网官网
  • 基于CNN和Transformer的分割技术的论文感悟
  • 怎么开设网站 优帮云简单描述一下网站制作的流程
  • 昌平网站建设自建房平面图设计软件
  • 佛山顺德网站建设公司哪家好做外贸网站的好处
  • 《计算》第九十章读书笔记
  • 快速掌握java中数组的排序
  • 从数据孤岛到生态协同:采购管理系统的跨系统集成方案
  • 厦门建站网址费用平台制作专业网站制作
  • 做网站的地方咋做网站
  • 提升板式换热器换热效率
  • 前端核心框架vue之项目篇(cli、vite 5/5)
  • 南昌网站建设咨询上海设计公司排名招聘
  • 网站用php做的吗网站建设的知名公司
  • 长春网站公司有哪些内容个人可以开发app软件吗
  • java-网络编程-UDP,TCP通信