国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

ES6精華:數(shù)值擴(kuò)展

newtrek / 2952人閱讀

摘要:基礎(chǔ)極值采用標(biāo)準(zhǔn)的位雙精度格式存儲數(shù)值。如果數(shù)值的精度超過此限度,第位及后面的會被丟棄。數(shù)值的極值分為兩種可表示的極值和可精確計算的極值浮點型不算。超過精度的數(shù)值可正確顯示,但由其計算得出的結(jié)果可能不準(zhǔn)確。整型數(shù)值安全區(qū)間。

ES6為數(shù)值增加了些常量和方法,使計算更為簡便安全。本篇概括了這中的精華知識。

1 基礎(chǔ) 1.1 極值

JS采用IEEE 754標(biāo)準(zhǔn)的64位雙精度格式存儲數(shù)值。
數(shù)值的精度最多可達(dá)到53個二進(jìn)制位(1個隱藏位和52個有效位)。
如果數(shù)值的精度超過此限度,第54位及后面的會被丟棄。

數(shù)值的極值分為兩種:可表示的極值和可精確計算的極值(浮點型不算)。
可表示的極值:[5e-324, 1.7976931348623157e+308]
可精確計算的極值:[1 - Math.pow(2, 53), Math.pow(2, 53) - 1]

超過精度的數(shù)值可正確顯示,但由其計算得出的結(jié)果可能不準(zhǔn)確。

let num = 9007199254741002;
console.log( num ); // 9007199254741002
console.log( num + 1 ); // 9007199254741004
console.log( num + 3 ); // 9007199254741004

let n1 = Math.pow(2, 53) - 1 + 1 + 1;
let n2 = Math.pow(2, 53) - 1 + 1 + 2;
console.log(n1 === n2); // true

對于整數(shù),最多能精確顯示16個十進(jìn)制位,超過會被截斷。
對于小數(shù),最多能精確顯示小數(shù)點后16個十進(jìn)制位,超過會被截斷。

超過的位數(shù)會被截斷。

console.log( 3.000000000000001 === 3 ); // false
console.log( 3.0000000000000001 === 3 ); // true
console.log( 0.123456789123456891 ); // 0.1234567891234569
1.2 進(jìn)制

二進(jìn)制:0b1000B
八進(jìn)制:0o1000O0100
十六進(jìn)制:0x1000X100
注意,可忽略0100格式表八進(jìn)制,因為嚴(yán)格模式下不允許使用。

進(jìn)制間的轉(zhuǎn)化
使用進(jìn)制的完整格式,通過toString在不同進(jìn)制間轉(zhuǎn)化。

console.log( (10).toString(2) ); // 1010
console.log( (0b100).toString(8) ); // 4
console.log( ("0o100").toString(16) ); // 40

使用進(jìn)制的值,通過parseInt將其它進(jìn)制轉(zhuǎn)換成十進(jìn)制。

console.log( parseInt(100, 2) ); // 4
console.log( parseInt(100, 8) ); // 64
console.log( parseInt("100", 16) ); // 256

使用進(jìn)制的完整格式,通過Number將其它進(jìn)制轉(zhuǎn)化成十進(jìn)制。

console.log( Number(0b100) ); // 4
console.log( Number("0o100") ); // 64
console.log( Number("0x100") ); // 256
2 Number

完整的API列表:地址。
此模塊的方法,不會默認(rèn)轉(zhuǎn)化期待為數(shù)值類型而實際不是的參數(shù)。

2.1 模塊化

將全局方法isFinite() & isNaN(),放到了Number模塊下。
兩者唯一的差別是,全局中的方法會默認(rèn)轉(zhuǎn)化非數(shù)值參數(shù),Number模塊下的不會。

console.log( isNaN("NaN") ); // true
- 等價于
console.log( isNaN(Number("NaN")) );

只要不是 NaN ,則為 false 。更為嚴(yán)格嚴(yán)謹(jǐn)。
console.log( Number.isNaN("NaN") ); // false
2.2 整數(shù)

增加了一些常量和方法為安全計算服務(wù)。

isInteger()
判斷一個數(shù)值是否為整數(shù)。非數(shù)直接為false
在JS中,整數(shù)和浮點數(shù)的儲存方式是相同的,所以2525.0被視為同一個值。

console.log( Number.isInteger("25") ); // false
console.log( Number.isInteger(25.0) ); // true
console.log( Number.isInteger(3.0000000000000002) ); // true

isSafeInteger()
判斷整型數(shù)值是否處于安全區(qū)間內(nèi)。非整型即為false
整型數(shù)值安全區(qū)間:[Number.MIN_SAFE_INTEGER, Number.MAX_SAFE_INTEGER]
判斷一個算式及其結(jié)果是否安全,需要驗證它的各個項以及結(jié)果。

isTrusty(9007199254740993, 990, 9007199254740993 - 990); // 報錯

function isTrusty(left, right, result) {
  if (Number.isSafeInteger(left)
    && Number.isSafeInteger(right)
    && Number.isSafeInteger(result)) {
    return result;
  }
  throw new RangeError("Operation cannot be trusted!");
}
2.3 誤差

JS能識別的最小精度為Number.EPSILON,即Math.pow(2, -52)
如果誤差小于此精度,就可以認(rèn)為這點誤差已經(jīng)沒有意義,即不存在誤差了。
在實際項目中,可以設(shè)置計算的容錯誤差,以對比兩個浮點數(shù)應(yīng)不應(yīng)該相同等等。

console.log( 0.1 + 0.2 ); // 0.30000000000000004
console.log( (0.1 + 0.2) === 0.3 ); // false
console.log( isEqualInErrorRange(0.1 + 0.2, 0.3) ); // true

function isEqualInErrorRange(left, right) {
  return Math.abs(left - right) < Number.EPSILON;
}

設(shè)定需要精確的位數(shù),將浮點型轉(zhuǎn)化成整型,來較為安全的計算浮點數(shù)。

console.log( countFloat(0.1, 0.2, "+", 14) ); // 0.3

function countFloat(a, b, sign, num) {
  let res;
  let times = Math.pow(10, num);
  let _a = Math.floor(a * times);
  let _b = Math.floor(b * times);
  
  switch (sign) {
    case "-":
      res = isTrusty(_a, _b, _a - _b);
      break;
    case "+":
      res = isTrusty(_a, _b, _a + _b);
      break;
    case "/":
      res = isTrusty(_a, _b, _a / _b);
      break;
    case "*":
      res = isTrusty(_a, _b, _a * _b);
      break;
  }
  
  return res / times;
}
3 Math

完整的API列表:地址。
此模塊的方法,會默認(rèn)調(diào)用Number()轉(zhuǎn)化,期待為數(shù)值類型而實際不是的參數(shù)。
此模塊新增了些,可以自行實現(xiàn)的簡易方法,直接查手冊會更有效,就不列舉了。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/95692.html

相關(guān)文章

  • ES6精華:正則擴(kuò)展

    摘要:本篇概括了中正則表達(dá)式新增部分的精華要點最好有的基礎(chǔ)。標(biāo)志使正則處于模式。關(guān)于的字符擴(kuò)展知識,可查看這里。四字節(jié)字符處于模式下的正則,可以正確識別位四字節(jié)字符。 本篇概括了ES6中正則表達(dá)式新增部分的精華要點(最好有ES5的基礎(chǔ))。 1 u 標(biāo)志 使正則處于Unicode模式。 關(guān)于ES6的字符擴(kuò)展知識,可查看這里。 1.1 四字節(jié)字符 處于Unicode模式下的正則,可以正確識別3...

    paulli3 評論0 收藏0
  • ES6精華:字符串擴(kuò)展

    摘要:四字節(jié)字符大幅增強(qiáng)了對字節(jié)位字符的支持。內(nèi)部使用編碼規(guī)則網(wǎng)頁通常為。字符固定為字節(jié),字節(jié)為位二進(jìn)制,其碼點小于。有些符號的碼點大于,需字節(jié)表示,即常說的位字符。表示方法新增一種表示字符的方法。用將碼點括起,使其可直接表示超過的值。 1 四字節(jié)字符 ES6大幅增強(qiáng)了對4字節(jié)(32位)字符的支持。 JS內(nèi)部使用UTF-16編碼規(guī)則(網(wǎng)頁通常為UTF-8)。 1字符固定為2字節(jié),1字節(jié)為...

    Jiavan 評論0 收藏0
  • Set & Map:新生的數(shù)據(jù)集合及其弱引用衍生

    摘要:前言新增了兩種基本的原生數(shù)據(jù)集合和加上和現(xiàn)在共有四種,以及由兩者衍生出的弱引用集合和。其本身是生成實例數(shù)據(jù)集合的構(gòu)造函數(shù),可以接受一個數(shù)組或具有接口的數(shù)據(jù)結(jié)構(gòu)作為參數(shù)用來初始化。返回鍵值對的遍歷器對象,鍵值對為鍵名鍵值。 前言 ES6新增了兩種基本的原生數(shù)據(jù)集合:Set和Map(加上Array和Object現(xiàn)在共有四種),以及由兩者衍生出的弱引用集合:WeakSet和WeakMap。從...

    AprilJ 評論0 收藏0
  • ES6精華:函數(shù)擴(kuò)展

    摘要:在函數(shù)方面的擴(kuò)展比較豐富也很實用,本篇概括了這中的精華知識。所以無法成為構(gòu)造函數(shù),不能使用操作符。參數(shù)將擴(kuò)展運算符作用于參數(shù),即為參數(shù)。聲明式,直接為函數(shù)名。通過構(gòu)造函數(shù)生成的,為。函數(shù)的屬性,在其描述對象的屬性上,為函數(shù)名。 ES6在函數(shù)方面的擴(kuò)展比較豐富也很實用,本篇概括了這中的精華知識。 1 箭頭函數(shù) 箭頭函數(shù)是ES6中定義函數(shù)的新形式。 新形式不僅簡化了定義方式,更為函數(shù)本身...

    lansheng228 評論0 收藏0
  • 細(xì)說JS數(shù)組

    摘要:數(shù)組元素的讀寫使用訪問數(shù)組元素時,將索引轉(zhuǎn)換為字符串,然后將其作為屬性名一樣使用。第一個參數(shù)應(yīng)該在前只展開一層數(shù)組元素不變,返回注意,只拼接第一層結(jié)構(gòu)。 此乃犀牛書(第七章 數(shù)組)讀書筆記,又結(jié)合了ES6中數(shù)組的擴(kuò)展部分做的知識梳理。精華部分就是手工繪制的兩張數(shù)組總結(jié)圖了。靈活運用數(shù)組的各種方法是基本功,是基本功,是基本功,重要的事情說三遍。好了,正文從下面開始~ 數(shù)組的基本概念 什么...

    starsfun 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<