JavaScript Побітові операції
JavaScript Побітові оператори
Оператор | Ім’я | Опис |
---|---|---|
& | AND | Встановлює кожен біт в 1, якщо обидва біти 1 |
| | OR | Встановлює кожен біт в 1, якщо один із двох бітів 1 |
^ | XOR | Встановлює кожен біт в 1, якщо лише один із двох бітів 1 |
~ | NOT | Інвертує всі біти |
<< | Здвиг ліворуч з нульовим заповненням | Здвигає ліворуч, вставляючи нулі праворуч та дозволяючи крайнім лівим бітам відпасти |
>> | Здвиг праворуч | Здвигає праворуч, вставляючи копії крайнього лівого біта зліва і дозволяючи крайнім правим бітам відпасти |
>>> | Здвиг праворуч з нульовим заповненням | Здвигає праворуч, вводячи нулі зліва і дозволяючи крайнім правим бітам відпасти |
Приклади
Операція | Результат | Те саме, що | Результат |
---|---|---|---|
5 & 1 | 1 | 0101 & 0001 | 0001 |
5 | 1 | 5 | 0101 | 0001 | 0101 |
~ 5 | 10 | ~0101 | 1010 |
5 << 1 | 10 | 0101 << 1 | 1010 |
5 ^ 1 | 4 | 0101 ^ 0001 | 0100 |
5 >> 1 | 2 | 0101 >> 1 | 0010 |
5 >>> 1 | 2 | 0101 >>> 1 | 0010 |
JavaScript використовує 32-бітові побітові операнди
JavaScript зберігає числа як 64-бітні числа з плаваючою комою, але всі побітові операції виконуються з 32-бітними бінарними числами.
Перед виконанням побітової операції JavaScript конвертує числа в 32-бітні цілі числа зі знаком.
Після виконання побітової операції, результат конвертується знову в 64-бітні JavaScript числа.
В наведених вище прикладах використовуються 4-бітні беззнакові бінарні числа. Із-за цього ~ 5 повертає 10.
Оскільки JavaScript використовує 32бітні цілі числа зі знаком, він не поверне 10. Він поверне -6.
00000000000000000000000000000101 (5)
11111111111111111111111111111010 (~5 = -6)
Ціле число зі знаком використовує крайній лівий біт як знак мінус.
Побітове AND
Коли побітове AND виконується для пари бітів, він повертає 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 |
Побітове OR
Коли для пари бітів виконується побітове 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 |
Побітове XOR
Коли побітове XOR виконується для пари бітів, повертає 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 |
JavaScript Побітове AND (&)
Побітове AND повертає 1 тільки якщо обидва біти дорівнюють 1:
Десяткове | Бінарне |
---|---|
5 | 00000000000000000000000000000101 |
1 | 00000000000000000000000000000001 |
5 & 1 | 00000000000000000000000000000001 (1) |
JavaScript Побітове OR (|)
Побітове OR повертає 1, якщо один із бітів дорівнює 1:
Десяткове | Бінарне |
---|---|
5 | 00000000000000000000000000000101 |
1 | 00000000000000000000000000000001 |
5 | 1 | 00000000000000000000000000000101 (5) |
JavaScript Побітове XOR (^)
Побітове XOR повертає 1, якщо біти різні:
Десяткове | Бінарне |
---|---|
5 | 00000000000000000000000000000101 |
1 | 00000000000000000000000000000001 |
5 ^ 1 | 00000000000000000000000000000100 (4) |
JavaScript Побітове NOT (~)
Десяткове | Бінарне |
---|---|
5 | 00000000000000000000000000000101 |
~5 | 11111111111111111111111111111010 (-6) |
JavaScript (Нульове заповнення) Побітовий здвиг вліво (<<)
Це здвиг вліво з нульовим заповненням. Один або кілька нульових біт вставляються справа, а крайні ліві біти відпадають:
Десяткове | Бінарне |
---|---|
5 | 00000000000000000000000000000101 |
5 << 1 | 00000000000000000000000000001010 (10) |
JavaScript (Збереження знаку) Побітовий здвиг вправо (>>)
Це знак, що зберігає правий здвиг. Копії самого лівого біту вставляються зліва, а крайні праві біти відпадають:
Десяткове | Бінарне |
---|---|
-5 | 11111111111111111111111111111011 |
-5 >> 1 | 11111111111111111111111111111101 (-3) |
JavaScript (Нульове заповнення) Здвиг вправо (>>>)
Це здвиг вправо з нульовим заповненням. Один або кілька нульових біт вставляються зліва, а крайні праві біти відпадають:
Десяткове | Бінарне |
---|---|
5 | 00000000000000000000000000000101 |
5 >>> 1 | 00000000000000000000000000000010 (2) |
Бінарні числа
Бінарні числа з одним набором бітів легко зрозуміти:
Бінарне представлення | Десяткове значення |
---|---|
00000000000000000000000000000001 | 1 |
00000000000000000000000000000010 | 2 |
00000000000000000000000000000100 | 4 |
00000000000000000000000000001000 | 8 |
00000000000000000000000000010000 | 16 |
00000000000000000000000000100000 | 32 |
00000000000000000000000001000000 | 64 |
Встановлення ще кількох бітів показує бінарний патерн:
Бінарне представлення | Десяткове значення |
---|---|
00000000000000000000000000000101 | 5 (4 + 1) |
00000000000000000000000000001101 | 13 (8 + 4 + 1) |
00000000000000000000000000101101 | 45 (32 + 8 + 4 + 1) |
JavaScript бінарні числа зберігаються в форматі доповнення до двух.
Це означає, що негативне число - це побітове NOT числа плюс 1:
Бінарне представлення | Десяткове значення |
---|---|
00000000000000000000000000000101 | 5 |
11111111111111111111111111111011 | -5 |
00000000000000000000000000000110 | 6 |
11111111111111111111111111111010 | -6 |
00000000000000000000000000101000 | 40 |
11111111111111111111111111011000 | -40 |