我的朋友已經(jīng)工作了 5 年,她過去一直擔(dān)任前端工程師。
不幸的是,她被老板批評了,因為她在工作中犯了一個錯誤,這是一個非常簡單但容易忽視的問題,我想也是很多朋友容易忽視的一個問題,今天我把它分享出來,希望能夠幫助到你,也希望大家遇到這個情況時,不要再放這個錯誤。
錯誤的描述
問題可能是這樣的,Lily在公司負責(zé)一個重大項目,其中一個模塊是顯示一條與數(shù)字相關(guān)的信息,這是后端工程師界面返回的信息(僅舉例)
各位小伙伴,我們調(diào)用getInfo接口會返回什么信息呢?會是 123456789123456789 嗎?
通過chrome瀏覽器的調(diào)試工具可以看到,似乎一切都和我們想象的一樣,結(jié)果是123456789123456789。
但是,頁面顯示的結(jié)果是123456789123456780,最后一位是0而不是9。
這到底是怎么回事?這太奇怪了,是不是有點崩潰。
分析出現(xiàn)問題的原因
現(xiàn)在,我們一起來分析一下原因。
我嘗試分析返回的數(shù)字,發(fā)現(xiàn)只有當(dāng)數(shù)字超過16位時才會出現(xiàn)最后幾位不一致的問題。
是不是因為數(shù)字太大,出現(xiàn)了精度損失?
Java語言中的Long類型是64位的,JavaScript語言中的Long類型是小于64位的嗎?
天哪,JavaScript 似乎沒有 Long 類型的數(shù)據(jù)!
實際上,在 JavaScript 中,我們使用 Number 來表示類型 number 的值。
Number 類型的總長度為 64 位。64位大致就是這樣分配的,其中53位代表小數(shù)位,10位代表指數(shù)位,1位代表符號位。因此,Number 整數(shù)的表示范圍為 -2^53 ~ 2^53。
讓我們嘗試在控制臺上輸出 JavaScript 中的最大值和最小值。
在其他語言中,例如 Java,Long 類型占用 64 個二進制位,最大值為 9223372036854774807 (2?³ — 1),長度約為 19 位。
在 JavaScript 中,由于 Number 類型的值也包含小數(shù),所以最大值為 9007199254740993 (2^53 - 1),長度約為 16 位。
所以當(dāng)Java向JSON返回16位以上的Long類型字段時,前端JavaScript獲取的數(shù)據(jù)會因為溢出而失去精度。
如何解決這個問題呢?
也許我們可以嘗試在前端解決這個問題,但我認為我們應(yīng)該尋求后端工程師的幫助。
我們應(yīng)該將可能超出范圍的數(shù)字類型(Long)變量轉(zhuǎn)換為字符串類型(String)。這個是我的個人處理方法。