LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

[點晴永久免費OA]關于 js 中的精度丟失問題

freeflydom
2023年6月26日 11:31 本文熱度 1048

前言

在 Javascript 中,由于采用了 IEEE 754 標準的浮點數(shù)表示方法,可能會導致精度丟失問題。這主要是因為浮點數(shù)在內(nèi)存中以二進制的形式存儲,而某些十進制數(shù)無法精確地轉(zhuǎn)換成二進制表示。當進行計算時,就會出現(xiàn)舍入誤差。

例如以下示例:


結(jié)果不精確是因為 0.1 和 0.2 無法用二進制無法精確地表示出來,進行運算時也會存在誤差。

本文將以此為例,從二進制轉(zhuǎn)化,存儲到計算來分析造成這一結(jié)果的根本原因,文章篇幅不多,希望看完后可以給你帶來一些收獲......

如何轉(zhuǎn)化?

首先我們要清楚整數(shù)和小數(shù)是如何轉(zhuǎn)化為二進制的。

整數(shù)部分:除2取余 + 逆序排列,示例如下:

8 / 2 = 4 ...... 0

4 / 2 = 2 ...... 0

2 / 2 = 1 ...... 0

1 / 2 = 0 ...... 1


整數(shù) 8 轉(zhuǎn)化為二進制的結(jié)果是:1000

小數(shù)部分:乘2取整 + 順序排列,示例如下:

0.1 * 2 = 0.2 ...... 0

0.2 * 2 = 0.4 ...... 0

0.4 * 2 = 0.8 ...... 0

0.8 * 2 = 1.6 ...... 1

0.6 * 2 = 1.2 ...... 1

0.2 * 2 = 0.4 ...... 0

...


小數(shù) 0.1 轉(zhuǎn)化為二進制的結(jié)果是:0.0001100110011...

如何存儲?

js 中 Number 類型使用 IEEE 754 標準 64 位存儲,為每個數(shù)值分配 64 位存儲空間,以科學計數(shù)法的方式進行存儲。形式如下:

1.xxxxxx * 2 ^ n 



64位存儲空間分為3個部分,包括 符號位、指數(shù)位小數(shù)位,如下圖所示:


符號位占 1 位,標記數(shù)值的正負,0 表示正數(shù),1 表示負數(shù)。

指數(shù)位占 11 位,值為一個固定值 1023 (IEEE 754 標準) + 科學計數(shù)法中的指數(shù)值,再將其轉(zhuǎn)為 11 位二進制。比如 0.1 = 0.00011001... = 1.1001... * 2 ^ (-4),指數(shù)位就為 1023 + (-4) = 1019,用 11 位二進制表示為 01111111011。

小數(shù)位占 52 位,用來存放小數(shù)點后的數(shù)值,以 0.1 為例,由于小數(shù)位只能存儲 52 位,又因為第 53 位為 1,所以截取需要往前進一位再保存,這里就造成了第一次的精度丟失。

相同的道理,所以 0.1 和 0.2 在內(nèi)存中就是這樣的:

如何計算?

最后就是將 64 位雙精度浮點數(shù)相加,首先我們把偏移量還原對齊,再進行相加,如下圖所示:


相加后發(fā)現(xiàn)小數(shù)部分有 53 位,由于小數(shù)位只能存儲 52 位,因此需要再次進行截取,這里就造成了第二次的精度丟失。將這個結(jié)果轉(zhuǎn)化為十進制就得到了一開始我們打印的結(jié)果。

這也就是為什么 0.1 + 0.2 不等于 0.3 的原因。

解決方法

可以使用一些第三方庫來解決,例如:

  • bignumber.js:提供了超高精度的數(shù)字處理能力,可以解決精度丟失問題。官方文檔

  • decimal.js:可以精確表示浮點數(shù),解決精度丟失問題。官方文檔

總結(jié)

  1. js 用二進制處理數(shù)據(jù),用 IEEE 754 雙精度浮點數(shù)標準存儲 Number 類型。

  2. 精度丟失是由于 IEEE 754 標準存儲位有限導致的。

  3. 過程中會有兩次精度丟失,一次在存儲,一次在相加。


原文鏈接



該文章在 2023/6/26 11:32:06 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運作、調(diào)度、堆場、車隊、財務費用、相關報表等業(yè)務管理,結(jié)合碼頭的業(yè)務特點,圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點晴WMS倉儲管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

黄频国产免费高清视频,久久不卡精品中文字幕一区,激情五月天AV电影在线观看,欧美国产韩国日本一区二区
亚洲国产人成在线观看69网站 | 在线日本妇人成熟免费a√午 | 日韩gv国产gv欧美旡码天堂 | 亚洲国产精品综合久久 | 亚洲欧美不卡高清在线观看 | 中文字幕在线天 |