欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

為什么JavaScript中0.1 + 0.2 != 0.3

 更新時間:2020年12月03日 14:18:10   作者:LuckXinXin  
這篇文章主要給大家介紹了關(guān)于為什么JavaScript中0.1 + 0.2 != 0.3的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

涉及面試題:為什么 0.1 + 0.2 != 0.3?如何解決這個問題?

原因,因為 JS 采用 IEEE 754雙精度版本(64位),并且只要采用 IEEE 754的語言都有該問題

我們都知道計算機是通過二進制來存儲東西的,那么 0.1 在二進制中會表示為

// (0011) 表示循環(huán)
0.1 = 2^-4 * 1.10011(0011)

我們可以發(fā)現(xiàn),0.1 在二進制中是無限循環(huán)的一些數(shù)字,其實不只是 0.1,其實很多十進制小數(shù)用二進制表示都是無限循環(huán)的。這樣其實沒什么問題,但是 JS采用的浮點數(shù)標準卻會裁剪掉我們的數(shù)字。

IEEE 754 雙精度版本(64位)將 64 位分為了三段

  • 第一位用來表示符號
  • 接下去的 11 位用來表示指數(shù)
  • 其他的位數(shù)用來表示有效位,也就是用二進制表示 0.1 中的 10011(0011)

那么這些循環(huán)的數(shù)字被裁剪了,就會出現(xiàn)精度丟失的問題,也就造成了 0.1 不再是 0.1 了,而是變成了 0.100000000000000002

0.100000000000000002 === 0.1 // true

那么同樣的,0.2 在二進制也是無限循環(huán)的,被裁剪后也失去了精度變成了 0.200000000000000002

0.200000000000000002 === 0.2 // true

所以這兩者相加不等于 0.3 而是 0.300000000000000004

0.1 + 0.2 === 0.30000000000000004 // true

那么可能你又會有一個疑問,既然 0.1 不是 0.1,那為什么 console.log(0.1) 卻是正確的呢?

因為在輸入內(nèi)容的時候,二進制被轉(zhuǎn)換為了十進制,十進制又被轉(zhuǎn)換為了字符串,在這個轉(zhuǎn)換的過程中發(fā)生了取近似值的過程,所以打印出來的其實是一個近似值,你也可以通過以下代碼來驗證

console.log(0.100000000000000002) // 0.1

解決

parseFloat((0.1 + 0.2).toFixed(10)) === 0.3 // true

到此這篇關(guān)于為什么JavaScript中0.1 + 0.2 != 0.3的文章就介紹到這了,更多相關(guān)JS中0.1 + 0.2 != 0.3內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 如何設(shè)置一定時間內(nèi)只能發(fā)送一次請求

    如何設(shè)置一定時間內(nèi)只能發(fā)送一次請求

    這篇文章主要介紹了如何設(shè)置一定時間內(nèi)只能發(fā)送一次請求,需要的朋友可以參考下
    2014-02-02
  • 微信小程序國際化探索實現(xiàn)(附源碼地址)

    微信小程序國際化探索實現(xiàn)(附源碼地址)

    這篇文章主要介紹了微信小程序國際化探索實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-05-05
  • 使用rollup打包JS的方法步驟

    使用rollup打包JS的方法步驟

    這篇文章主要介紹了使用rollup打包JS的方法步驟,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • JS面試題之如何判斷兩個數(shù)組的內(nèi)容是否相等

    JS面試題之如何判斷兩個數(shù)組的內(nèi)容是否相等

    這篇文章主要為大家詳細介紹了JavaScript面試的??碱},即如何判斷兩個數(shù)組的內(nèi)容是否相等,文中的示例方法講解詳細,需要的小伙伴可以參考一下
    2023-10-10
  • JavaScript如何監(jiān)測數(shù)組的變化

    JavaScript如何監(jiān)測數(shù)組的變化

    最近在造輪子的時候遇到了這么一個問題,那就是數(shù)組在調(diào)用內(nèi)部方法的時候怎么才可以監(jiān)聽到數(shù)組發(fā)生了變化,這篇文章主要給大家介紹了關(guān)于JavaScript如何監(jiān)測數(shù)組變化的相關(guān)資料,需要的朋友可以參考下
    2021-07-07
  • 仿Google和Windows Live的拖拽

    仿Google和Windows Live的拖拽

    仿Google和Windows Live的拖拽...
    2006-11-11
  • javascript實現(xiàn)3D變換的立體圓圈實例

    javascript實現(xiàn)3D變換的立體圓圈實例

    這篇文章主要介紹了javascript實現(xiàn)3D變換的立體圓圈效果,涉及javascript動態(tài)操作頁面元素實現(xiàn)滾動與變色的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-08-08
  • JavaScript同步與異步任務(wù)問題詳解

    JavaScript同步與異步任務(wù)問題詳解

    這篇文章主要介紹了JavaScript事件循環(huán)同步任務(wù)與異步任務(wù),文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下
    2022-07-07
  • TypeScript條件類型與內(nèi)置條件類型超詳細講解

    TypeScript條件類型與內(nèi)置條件類型超詳細講解

    我們可以使用TypeScript中的條件類型來根據(jù)邏輯定義某些類型,就像是在編寫代碼那樣。它采用的語法和我們在JavaScript中熟悉的三元運算符很像:condition ? ifConditionTrue : ifConditionFalse。我們來看看他是怎么工作的
    2023-03-03
  • javascript 極速 隱藏/顯示萬行表格列只需 60毫秒

    javascript 極速 隱藏/顯示萬行表格列只需 60毫秒

    隱藏表格列 這種方式的效率極低。例如,隱藏一個千行表格的某列,在我的筆記本(P4 M 1.4G,768M內(nèi)存)上執(zhí)行需要約 4000毫秒的時間,令人無法忍受。
    2009-03-03

最新評論