目录
所谓位运算,就是对二进制的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? "偶数":"奇数");
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步