C Bit Manipulation, OR, XOR, Shift is an important C Language topic because it appears in real projects, debugging sessions, and interviews. Learn the meaning first, then connect it to a small working example so the rule does not stay abstract.
For this page, focus on what problem C Bit Manipulation, OR, XOR, Shift solves, where developers usually make mistakes, and how to verify the result. The audit note for this lesson was: under 650 content words; limited checklist/practice/mistake/FAQ notes .
A strong understanding of C Bit Manipulation, OR, XOR, Shift should include syntax, behavior, one realistic use case, one failure case, and one quick way to check your work with tools or output.
C Bit Manipulation OR XOR Shift should be studied as a practical C Language lesson, not as a label. Start by naming the input, the rule that changes the input, and the result a learner should be able to predict after reading the page.
In the c-language > bit-manipulation page, the notes should connect the definition with a working scenario, a mistake that beginners actually make, and the exact check that proves the fix. That makes the topic useful for coding, debugging, and interview revision.
Bit manipulation means directly operating on the individual bits of an integer using bitwise operators. It is used in systems programming, embedded systems, cryptography, compression, and performance-critical code where you need to pack multiple values into a single integer or toggle hardware flags.
| Operator | Symbol | Description | Example (a=5, b=3) |
|---|---|---|---|
| AND | & | 1 if both bits are 1 | 5 & 3 = 1 (0101 & 0011 = 0001) |
| OR | | | 1 if either bit is 1 | 5 | 3 = 7 (0101 | 0011 = 0111) |
| XOR | ^ | 1 if bits differ | 5 ^ 3 = 6 (0101 ^ 0011 = 0110) |
| NOT | ~ | Flips all bits | ~5 = -6 (two's complement) |
| Left Shift | << | Shift bits left (multiply by 2) | 5 << 1 = 10 |
| Right Shift | >> | Shift bits right (divide by 2) | 5 >> 1 = 2 |
#include <stdio.h>
void printBinary(unsigned int n) {
for (int i = 7; i >= 0; i--) {
printf("%d", (n >> i) & 1);
}
}
int main() {
unsigned int a = 5; // 0000 0101
unsigned int b = 3; // 0000 0011
printf("a = %u (", a); printBinary(a); printf(")\n");
printf("b = %u (", b); printBinary(b); printf(")\n\n");
printf("a & b = %u (AND)\n", a & b); // 1
printf("a | b = %u (OR)\n", a | b); // 7
printf("a ^ b = %u (XOR)\n", a ^ b); // 6
printf("~a = %d (NOT)\n", ~a); // -6 (signed)
printf("a << 1 = %u (LEFT SHIFT = a*2)\n", a << 1); // 10
printf("a >> 1 = %u (RIGHT SHIFT = a/2)\n", a >> 1); // 2
return 0;
}
/*
a = 5 (00000101)
b = 3 (00000011)
a & b = 1 (AND)
a | b = 7 (OR)
a ^ b = 6 (XOR)
~a = -6 (NOT)
a << 1 = 10 (LEFT SHIFT = a*2)
a >> 1 = 2 (RIGHT SHIFT = a/2)
*/
These patterns appear constantly in real-world C code:
#include <stdio.h>
int main() {
unsigned int n = 0b00001010; // 10 in binary
int pos = 2; // bit position (0 = rightmost)
// SET bit at position pos (force it to 1)
n = n | (1 << pos);
printf("After SET bit %d: %u\n", pos, n); // 14 (00001110)
// CLEAR bit at position pos (force it to 0)
n = n & ~(1 << pos);
printf("After CLEAR bit %d: %u\n", pos, n); // 10 (00001010)
// TOGGLE bit at position pos (flip it)
n = n ^ (1 << pos);
printf("After TOGGLE bit %d: %u\n", pos, n); // 14 (00001110)
// CHECK if bit at position pos is set
int isSet = (n >> pos) & 1;
printf("Bit %d is %s\n", pos, isSet ? "SET" : "CLEAR");
// Check if number is even or odd using bit 0
int x = 17;
printf("\n%d is %s\n", x, (x & 1) ? "odd" : "even");
// Check if power of 2: n & (n-1) == 0
int vals[] = {1, 2, 3, 4, 8, 12, 16};
for (int i = 0; i < 7; i++) {
int v = vals[i];
printf("%2d is %s power of 2\n", v,
(v > 0 && (v & (v-1)) == 0) ? "a" : "NOT a");
}
return 0;
}
Bit fields let you pack multiple small values into a single integer within a struct. This is heavily used in embedded systems to map hardware registers.
#include <stdio.h>
// Permissions struct using bit fields
// Each field uses only the specified number of bits
struct Permissions {
unsigned int read : 1; // 1 bit
unsigned int write : 1; // 1 bit
unsigned int execute : 1; // 1 bit
unsigned int admin : 1; // 1 bit
}; // Total: 4 bits packed into one int
int main() {
struct Permissions user = {1, 1, 0, 0}; // read+write, no exec, no admin
printf("Read: %d\n", user.read); // 1
printf("Write: %d\n", user.write); // 1
printf("Execute: %d\n", user.execute); // 0
printf("Admin: %d\n", user.admin); // 0
// Grant execute permission
user.execute = 1;
printf("\nAfter granting execute:\n");
printf("Execute: %d\n", user.execute); // 1
printf("\nSize of Permissions struct: %zu bytes\n",
sizeof(struct Permissions)); // 4 bytes (one int)
return 0;
}
#include <stdio.h>
int main() {
int a = 15, b = 27;
printf("Before: a=%d, b=%d\n", a, b);
// XOR swap - works because a^b^b = a and a^a^b = b
a = a ^ b; // a = 15^27
b = a ^ b; // b = (15^27)^27 = 15
a = a ^ b; // a = (15^27)^15 = 27
printf("After: a=%d, b=%d\n", a, b); // a=27, b=15
// Note: only works when a and b are different variables
// XOR swap with same variable: a ^= a -> a becomes 0!
return 0;
}
When studying C Bit Manipulation, OR, XOR, Shift, separate three things: the concept, the syntax, and the situation where it is useful. This prevents the lesson from becoming a list of commands with no practical meaning.
In C Language, C Bit Manipulation, OR, XOR, Shift becomes easier when you build a tiny example first, then increase complexity. Add one realistic input, one invalid or boundary input, and one explanation of why the result changes.
#include <stdio.h>
int main(void) {
printf("C Bit Manipulation OR XOR Shift: normal path\n");
return 0;
}
#include <stdio.h>
int main(void) {
int count = 0;
if (count == 0) printf("C Bit Manipulation OR XOR Shift: empty input\n");
return 0;
}
Memorizing C Bit Manipulation OR XOR Shift without the situation where it is useful.
Connect C Bit Manipulation OR XOR Shift to a concrete C Language task.
Testing C Bit Manipulation OR XOR Shift only with the perfect input.
Include empty, missing, duplicate, incompatible, or failed cases when relevant.
Changing code before reading the visible symptom or error message.
Inspect the output, state, configuration, or stack trace connected to C Bit Manipulation OR XOR Shift.
Memorizing C Bit Manipulation OR XOR Shift without the situation where it is useful.
Connect C Bit Manipulation OR XOR Shift to a concrete C Language task.
The common mistake is memorizing syntax without understanding when the behavior changes or fails.
Remember the problem it solves in C Language, then attach the syntax or steps to that problem.
You can predict the result of a small example, explain a failure case, and choose it over a nearby alternative for a clear reason.
They often copy the syntax but skip the state, input, dependency, selector, route, type, or configuration that controls the behavior.
Explore 500+ free tutorials across 20+ languages and frameworks.