DEV Community

Cover image for How to do bit manipulation in JavaScript
Coderslang: Become a Software Engineer
Coderslang: Become a Software Engineer

Posted on • Edited on • Originally published at learn.coderslang.com

How to do bit manipulation in JavaScript

Bitwise operations aren’t very common in JavaScript, but sometimes they’re indispensable.

To understand how bitwise operations work in JavaScript, you need to first understand what a binary system is and how to convert numbers from decimal to binary and back again.

If you're new to the topic, you can start with the introduction to the binary number system.

A broad review of all bitwise operators in JS

Operator Common name Description
& AND If both bits are 1 - the result is 1. If at least one of them is 0 - the result is 0.
` ` OR
^ XOR If both bits are the same - the result is 0. If the bits are different - the result is 1.
~ NOT Inverts all bits in a number.
<< Left shift Shifts all bits to the left, fills empty slots with zeros.
>> Signed right shift Shifts all bits to the right, fills empty slots with the leftmost bit, to maintain the sign of the number.
>>> Unsigned right shift Shifts all bits to the right, fills empty slots with zeros.

Examples and usage

Bitwise operators in JavaScript are quite hard to understand if you apply them to decimal numbers.

I suggest starting with a piece of paper and a pencil and write down all the numbers in binary.

AND, OR, XOR operators

Operators &, | and ^ require 2 numbers to function properly. They compare the bits in these numbers one by one applying the rules from the table above.

Let’s try them out. The binary representation of decimal number is in the comment:

const x = 5;   // 0101
const y = 6;   // 0110
Enter fullscreen mode Exit fullscreen mode

It's easier if you write the binary numbers one under the other like this:

AND 0101     OR 0101     XOR 0101
    0110        0110         0110
    ----        ----         ----
    0100        0111         0011
Enter fullscreen mode Exit fullscreen mode

Now, we can add console.log and see if our calculations were right:

console.log(x & y);  // 4
console.log(x || y); // 7
console.log(x ^ y);  // 3
Enter fullscreen mode Exit fullscreen mode

An important trick with XOR is that if you place the same number on both sides of it, you’ll always get zero.

console.log(x ^ x);  // 0
console.log(y ^ y);  // 0
Enter fullscreen mode Exit fullscreen mode

On the contrary, if you replace ^ with either & or | the number won’t change.

NOT operator

The ~ operator is a different beast. It’s called a unary operator as it applies to a single operand (number).

NOT 0101 => 1010
NOT 0110 => 1001
Enter fullscreen mode Exit fullscreen mode
console.log(~x);     // -6
console.log(~y);     // -7
Enter fullscreen mode Exit fullscreen mode

The sign flips as it’s determined by the leftmost bit in a JavaScript number. If it’s set to 0, the number is positive, 1 - it’s negative.

If you apply the ~ operator the number twice, you’ll get back to where you started:

console.log(~~x);     // 5
Enter fullscreen mode Exit fullscreen mode

Bitwise shift operators

The bitwise shift requires 2 numbers to run. The first one is the actual number that’s being shifted and the second is the number of binary digits that should be moved.

Left shift

Shifting the binary number 1 digit to the left is the same as making it two times bigger. Unless it’s already so big that there are no bits to hold the result of such a multiplication.

console.log(x << 1);   // 10
console.log(y << 2);   // 24
Enter fullscreen mode Exit fullscreen mode

Right shift

The right shift, contrary to the left shift, makes the number smaller. If the number is large enough and no significant bits will "fall off", it will divide the number by 2. In our case, with the small numbers, it’s not so easy:

console.log(x >> 1);   // 2
console.log(y >> 2);   // 1
Enter fullscreen mode Exit fullscreen mode

Don't be lazy, check the binary calculation yourself!

Unsigned right shift

The unsigned right shift is different from the regular right shift as it doesn’t maintain the sign of the number. When applied to negative numbers it will always turn them positive as the leftmost bit will become 0.

const n = 100;   
const m = -100;

console.log(n >>> 2);   // 25
console.log(m >>> 2);   // 1073741799
Enter fullscreen mode Exit fullscreen mode

There were no surprises with 100 and it expectedly got 4 times smaller.

But do you understand why -100 turned into 1073741799?

Conclusion

If you’re doing web development using JavaScript then you most likely will never have to use bitwise operators in your everyday tasks.

Some interviewers, though, like this topic a lot and might ask you to implement some tasks using only bitwise operations. For example, determine if the number is even.

If you’re looking to prepare for the technical interview you might find my app Coderslang very helpful. It has over 1500 questions in JavaScript, HTML/CSS, Java, C#, Node.js, React.js, React Native, and QA. Download it on iOS or Android.

I've also posted a FREE ebook with 35 top JavaScript interview questions.

Top comments (0)