[英]Bit Testing.Counting the bits
为什么打印47(00101111)的第6位为1。从右边开始,从1开始计数?
#include <stdio.h>
#include <stdlib.h>
int main()
{
int mask1,mask2;
//bit testing;
mask1=1<<3;
mask2=1<<6;
if(47&mask1!=0)
printf("\n bit number 3 is 1");
else
printf("\n bit number 3 is 0");
if(47&mask2!=0)
printf("\n bit number 6 is 1");
else
printf("\n bit number 6 is 0");
return 0;
}
按位AND运算符&
优先级低于不等式运算符!=
。 所以这:
47&mask1!=0
是相同的:
47&(mask1!=0)
如下添加括号:
(47&mask1)!=0
您将获得预期的结果。 确保对mask2
进行相同的检查。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.