目录
所谓位运算,就是对二进制的0或1运算
位运算符有6个:
注意:他们的优先级不同!!!



按位与&:
printf("按位与:& \n");
printf("%d\n",10&5); //十进制形式 ————输出结果为0
printf("%d\n", 0b1010 & 0b0101);//二进制形式 ————输出结果为0

按位或 | :
printf("%d\n",0b1010 | 0b0101);//————输出结果为15

按位取反 ~ :
printf("%d %d\n", ~- 1, ~0); //输出结果为0 -1
printf("%d %u\n", ~- 1, ~0); //输出结果为0 4294967295 %u无符号对0取反为最大值

按位异或:
printf("%d\n", 10 ^ 5); //输出结果为15

按位左移:
printf("%d %d\n", 10 << 1, 10 << 2); //10的二进制左移一位和左移两位,结果为20,40

按位右移:
注:由于首位符号位问题,正整数右移首位补0,负数补1
printf("%d %d\n", 10 >> 1, 10 >> 2);//输出结果为5 2
printf("%d\n", -1 >> 1);//输出结果为-1 由于-1为负数,右移补1仍为-1

一些简单应用:两个相同的数异或之后结果会等于
0
,即
n ^ n = 0
。并且任何数与
0
异或等于它本身,即
n ^ 0 = n
判断奇偶性:
int x = 10;
printf("%s\n", x&2? "偶数":"奇数");
本文介绍了位运算的基本概念,包括按位与、按位或、按位取反、按位异或、按位左移和按位右移,并通过示例展示了它们的运算规则和应用场景,如判断奇偶性和简单的逻辑运算。位运算是计算机科学中的基础操作,对于理解底层计算原理至关重要。
3761





