JavaScript 32位整型無符號操作

microsoft_kk發表於2014-07-31

在 JavaScript 中,所有整數字變數預設都是有符號整數,這意味著什麼呢?

有符號整數使用 31 位表示整數的數值,用第 32 位表示整數的符號,0 表示正數,1 表示負數。
數值範圍從 -2^31 - 2^31-1 即 -2147483648 到 2147483647。

JavaScript 進行位操作時,是採用32位 有符號 整型,這意味著其轉換的結果也是32位有符號整型。 有些時候,我們進行移位會出現意想不到的結果,以下是C語言 與 JS 的對比。

C語言

1 unsigned int a = 3774191835u;
2 unsigned int b = a >> 2;
3 /* b == 943547958 */
JavaScript

1 var a = 3774191835;
2 var b = a >> 2;
3 /* b == -130193866 */
可以看到,JavaScript 進行位運算時,是採用的有符號整型,故我們得到了不一樣的結果。 怎麼解決呢?

我們可以把JavaScript 中的有符號數,轉換成無符號數。只需要進行 >>>0 移位操作就好了。

最好不要使用 >> ,推薦使用 >>> 因為最左邊一位會被解析成符號位,當數字溢位時,會被解析成負數。

unsigned = signed>>>0;
通過使用無符號右移運算子,位動位數為0,可以將32位有符號整數,轉化為32位無符號整數。
signed = unsigned << 0;
通過使用左移運算子,位動位數為0,可以將32位無符號整數,轉化為32位有符號整數。

相關文章