Javascript中大數(shù)處理

1鲜戒、IEEE 754 雙精確度浮點數(shù)(Double 64 Bits)中尾數(shù)部分是用來存儲整數(shù)的有效位數(shù),為 52 位,加上省略的一位 1 可以保存的實際數(shù)值為

Math.pow(2, 53) // 9007199254740992

Number.MAX_SAFE_INTEGER // 最大安全整數(shù) 9007199254740991 
Number.MIN_SAFE_INTEGER // 最小安全整數(shù) -9007199254740991

2、實際存儲時 如果超過 最值竣灌,會發(fā)生轉化

const num = 200000436035958034;
console.log(num); // 200000436035958050

還有常見的場景是 經(jīng)過JSON.parse 序列化后 大數(shù)超過最值, 也會被轉化秆麸; 原因是 JSON 的schema 是 object, array, number, or string 初嘹, 所以對數(shù)字自動轉化

3、處理方式

  • 轉為字符串: 最為常見
  • BigInt
// 方法1
200000436035958034n; // 200000436035958034n
// 方法2
BigInt('200000436035958034') // 200000436035958034n

// 注意要使用字符串否則還是會被轉義
BigInt(200000436035958034) // 200000436035958048n 這不是一個正確的結果

但BigInt 類型 不能直接進行JOSN.parse 沮趣, 會報錯屯烦,因為不符合JSON的schema

  • 第三方庫: json-bigint
    不要直接使用 JSON.parse() ,在接收數(shù)據(jù)流之后房铭,先通過字符串方式進行解析驻龟,利用 json-bigint 這個庫,會自動的將超過 2 的 53 次方類型的數(shù)值轉為一個 BigInt 類型缸匪,再設置一個參數(shù) storeAsString: true 會將 BigInt 自動轉為字符串迅脐。
    node端使用:
const http = require('http');
const JSONbig = require('json-bigint')({ 'storeAsString': true});

http.createServer((req, res) => {
  if (req.method === 'POST') {
    let data = '';
    req.on('data', chunk => {
      data += chunk;
    });

    req.on('end', () => {
      try {
        // 使用第三方庫進行 JSON 序列化
        const obj = JSONbig.parse(data)
        console.log('經(jīng)過 JSON 反序列化之后:', obj);

        res.setHeader("Content-Type", "application/json");
        res.end(data);
      } catch(e) {
        console.error(e);
        res.statusCode = 400;
        res.end("Invalid JSON");
      }
    });
  } else {
    res.end('OK');
  }
}).listen(3000)

axios中使用:

const axios = require('axios').default;
const JSONbig = require('json-bigint')({ 'storeAsString': true});

const request = axios.create({
  baseURL: 'http://localhost:3000',
  transformResponse: [function (data) {
    return JSONbig.parse(data)
  }],
});

request({
  url: '/api/test'
}).then(response => {
  // 200000436035958034
  console.log(response.data.num);
});

總結自Node.js 中遇到大數(shù)處理精度丟失如何解決?前端也適用豪嗽!

hi~ 今天的你開心不~~

?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市豌骏,隨后出現(xiàn)的幾起案子龟梦,更是在濱河造成了極大的恐慌,老刑警劉巖窃躲,帶你破解...
    沈念sama閱讀 219,366評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件计贰,死亡現(xiàn)場離奇詭異,居然都是意外死亡蒂窒,警方通過查閱死者的電腦和手機躁倒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評論 3 395
  • 文/潘曉璐 我一進店門荞怒,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人秧秉,你說我怎么就攤上這事褐桌。” “怎么了象迎?”我有些...
    開封第一講書人閱讀 165,689評論 0 356
  • 文/不壞的土叔 我叫張陵荧嵌,是天一觀的道長。 經(jīng)常有香客問我砾淌,道長啦撮,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,925評論 1 295
  • 正文 為了忘掉前任汪厨,我火速辦了婚禮赃春,結果婚禮上,老公的妹妹穿的比我還像新娘劫乱。我一直安慰自己织中,他們只是感情好,可當我...
    茶點故事閱讀 67,942評論 6 392
  • 文/花漫 我一把揭開白布要拂。 她就那樣靜靜地躺著抠璃,像睡著了一般。 火紅的嫁衣襯著肌膚如雪脱惰。 梳的紋絲不亂的頭發(fā)上搏嗡,一...
    開封第一講書人閱讀 51,727評論 1 305
  • 那天,我揣著相機與錄音拉一,去河邊找鬼采盒。 笑死,一個胖子當著我的面吹牛蔚润,可吹牛的內(nèi)容都是我干的磅氨。 我是一名探鬼主播,決...
    沈念sama閱讀 40,447評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼嫡纠,長吁一口氣:“原來是場噩夢啊……” “哼烦租!你這毒婦竟也來了?” 一聲冷哼從身側響起除盏,我...
    開封第一講書人閱讀 39,349評論 0 276
  • 序言:老撾萬榮一對情侶失蹤叉橱,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后者蠕,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體窃祝,經(jīng)...
    沈念sama閱讀 45,820評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,990評論 3 337
  • 正文 我和宋清朗相戀三年踱侣,在試婚紗的時候發(fā)現(xiàn)自己被綠了粪小。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片大磺。...
    茶點故事閱讀 40,127評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖探膊,靈堂內(nèi)的尸體忽然破棺而出杠愧,到底是詐尸還是另有隱情,我是刑警寧澤突想,帶...
    沈念sama閱讀 35,812評論 5 346
  • 正文 年R本政府宣布殴蹄,位于F島的核電站,受9級特大地震影響猾担,放射性物質發(fā)生泄漏袭灯。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,471評論 3 331
  • 文/蒙蒙 一绑嘹、第九天 我趴在偏房一處隱蔽的房頂上張望稽荧。 院中可真熱鬧,春花似錦工腋、人聲如沸姨丈。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蟋恬。三九已至,卻和暖如春趁冈,著一層夾襖步出監(jiān)牢的瞬間歼争,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評論 1 272
  • 我被黑心中介騙來泰國打工渗勘, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留沐绒,地道東北人。 一個月前我還...
    沈念sama閱讀 48,388評論 3 373
  • 正文 我出身青樓旺坠,卻偏偏與公主長得像乔遮,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子取刃,可洞房花燭夜當晚...
    茶點故事閱讀 45,066評論 2 355

推薦閱讀更多精彩內(nèi)容