掃二維碼與項目經理溝通
我們在微信上24小時期待你的聲音
解答本文疑問/技術咨詢/運營咨詢/技術建議/互聯(lián)網交流
JavaScript提供了一組位運算符,可以用來做簡單的位運算。

目前成都創(chuàng)新互聯(lián)公司已為上千的企業(yè)提供了網站建設、域名、網絡空間、成都網站托管、企業(yè)網站設計、永泰網站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
與Java等語言不同,JavaScript的數(shù)值型默認是浮點型,在進行位運算的時候需要先轉換為整型才能運算,所以JavaScript的位運算效率比較低。
| 運算符 | 名稱 | 描述 |
|---|---|---|
| & | AND | 如果兩位都是 1 則設置每位為 1 |
| | | OR | 如果兩位之一為 1 則設置每位為 1 |
| ^ | XOR | 如果兩位只有一位為 1 則設置每位為 1 |
| ~ | NOT | 反轉所有位 |
| << | 零填充左位移 | 通過從右推入零向左位移,并使最左邊的位脫落。 |
| >> | 有符號右位移 | 通過從左推入最左位的拷貝來向右位移,并使最右邊的位脫落。 |
| >>> | 零填充右位移 | 通過從左推入零來向右位移,并使最右邊的位脫落。 |
| 操作 | 結果 | 等同于 | 結果 |
|---|---|---|---|
| 5 & 1 | 1 | 0101 & 0001 | 0001 |
| 5 | 1 | 5 | 0101 | 0001 | 0101 |
| 5 ^ 1 | 4 | 0101 ^ 0001 | 0100 |
| ~ 5 | -6 | ~0101 | 1010 |
| 5 << 1 | 10 | 0101 << 1 | 1010 |
| 5 >> 1 | 2 | 0101 >> 1 | 0010 |
| 5 >>> 1 | 2 | 0101 >>> 1 | 0010 |
JavaScript 將數(shù)字存儲為 64 位浮點數(shù),但所有按位運算都以 32 位二進制數(shù)執(zhí)行。
在執(zhí)行位運算之前,JavaScript 將數(shù)字轉換為 32 位有符號整數(shù)。
執(zhí)行按位操作后,結果將轉換回 64 位 JavaScript 數(shù)。
上面的例子使用 4 位無符號二進制數(shù)。所以 ~ 5 返回 10。
由于 JavaScript 使用 32 位有符號整數(shù),JavaScript 將返回 -6。
00000000000000000000000000000101 (5)
11111111111111111111111111111010 (~5 = -6)
有符號整數(shù)使用最左邊的位作為減號。
當對一對數(shù)位執(zhí)行位運算 AND 時,如果數(shù)位均為 1 則返回 1。
| 運算 | 結果 |
|---|---|
| 0 & 0 | 0 |
| 0 & 1 | 0 |
| 1 & 0 | 0 |
| 1 & 1 | 1 |
| 運算 | 結果 |
|---|---|
| 1111 & 0000 | 0000 |
| 1111 & 0001 | 0001 |
| 1111 & 0010 | 0010 |
| 1111 & 0100 | 0100 |
當對一對數(shù)位執(zhí)行位運算 OR 時,如果其中一位是 1 則返回 1:
| 運算 | 結果 |
|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 1 |
| 操作 | 結果 |
|---|---|
| 1111 | 0000 | 1111 |
| 1111 | 0001 | 1111 |
| 1111 | 0010 | 1111 |
| 1111 | 0100 | 1111 |
當對一對數(shù)位進行位運算 XOR 時,如果數(shù)位是不同的則返回 1:
| 運算 | 結果 |
|---|---|
| 0 ^ 0 | 0 |
| 0 ^ 1 | 1 |
| 1 ^ 0 | 1 |
| 1 ^ 1 | 0 |
| 運算 | 結果 |
|---|---|
| 1111 ^ 0000 | 1111 |
| 1111 ^ 0001 | 1110 |
| 1111 ^ 0010 | 1101 |
| 1111 ^ 0100 | 1011 |
如果位數(shù)都是 1,則位運算 AND 返回 1:
| 十進制 | 二進制 |
|---|---|
| 5 | 00000000000000000000000000000101 |
| 1 | 00000000000000000000000000000001 |
| 5 & 1 | 00000000000000000000000000000001 (1) |
var x = 5 & 1;
如果數(shù)位之一是 1,則位運算 OR 返回 1:
| 十進制 | 二進制 |
|---|---|
| 5 | 00000000000000000000000000000101 |
| 1 | 00000000000000000000000000000001 |
| 5 | 1 | 00000000000000000000000000000101 (5) |
var x = 5 | 1;
如果數(shù)位是不同的,則 XOR 返回 1:
| 十進制 | 二進制 |
|---|---|
| 5 | 00000000000000000000000000000101 |
| 1 | 00000000000000000000000000000001 |
| 5 ^ 1 | 00000000000000000000000000000100 (4) |
var x = 5 ^ 1;
| 十進制 | 二進制 |
|---|---|
| 5 | 00000000000000000000000000000101 |
| ~5 | 11111111111111111111111111111010 (-6) |
var x = ~5;
這是零填充的左移。一個或多個零數(shù)位從右被推入,最左側的數(shù)位被移除:
| 十進制 | 二進制 |
|---|---|
| 5 | 00000000000000000000000000000101 |
| 5 << 1 | 00000000000000000000000000001010 (10) |
var x = 5 << 1;
這是保留符號的右移。最左側的數(shù)位被從左側推入,最右側的數(shù)位被移出:
| 十進制 | 二進制 |
|---|---|
| -5 | 11111111111111111111111111111011 |
| -5 >> 1 | 11111111111111111111111111111101 (-3) |
var x = -5 >> 1;
這是零填充的右移。一個或多個零數(shù)位從左側被推入,最右側的數(shù)位被移出:
| 十進制 | 二進制 |
|---|---|
| 5 | 00000000000000000000000000000101 |
| 5 >>> 1 | 00000000000000000000000000000010 (2) |
var x = 5 >>> 1;
僅設置一位的 32 位整數(shù)很好理解:
| 二進制表示 | 十進制值 |
|---|---|
| 00000000000000000000000000000001 | 1 |
| 00000000000000000000000000000010 | 2 |
| 00000000000000000000000000000100 | 4 |
| 00000000000000000000000000001000 | 8 |
| 00000000000000000000000000010000 | 16 |
| 00000000000000000000000000100000 | 32 |
| 00000000000000000000000001000000 | 64 |
多設置一些數(shù)位揭示了二進制的模式:
| 二進制表示 | 十進制值 |
|---|---|
| 00000000000000000000000000000101 | 5 (4 + 1) |
| 00000000000000000000000000101000 | 40 (32 + 8) |
| 00000000000000000000000000101101 | 45 (32 + 8 + 4 + 1) |
負數(shù)是正數(shù)的二進制補碼加 1:
| 二進制表示 | 十進制值 |
|---|---|
| 00000000000000000000000000000101 | 5 |
| 11111111111111111111111111111011 | -5 |
| 00000000000000000000000000101000 | 40 |
| 11111111111111111111111111011000 | -40 |
| 11111111111111111111111111011001 | -41 |
function dec2bin(dec){
return (dec >>> 0).toString(2);
}
function bin2dec(bin){
return parseInt(bin, 2).toString(10);
}

我們在微信上24小時期待你的聲音
解答本文疑問/技術咨詢/運營咨詢/技術建議/互聯(lián)網交流