位与运算&小于相等判断==的优先级

简介: 位与运算&小于相等判断==的优先级

在编写函数,获取一个数的二进制表示中1的数量时,如果采用左移后与最高位为1的数,进行位与运算。那么运算符的优先级需要特别注意。

完整函数如下,其中0x80000000表示32位整数中最高位为1的数,二进制表示为1000 0000 0000 0000 0000 0000 0000 0000

int getNumOf1InBin1(int n)
{
    int cnt = 0;
    while (n != 0){
        if ((n & 0x80000000) == 0x80000000) //与运算需要加括号
            cnt++;
        n <<= 1;
    }
    return cnt;
}

如果写成

if (n & 0x80000000 == 0x80000000)

则先判断 两个负数是否相等,当然是相等的,结果为1,n再与1进行与运算。显然,这里的逻辑不是我们想要的。因此,需要加括号,先做与运算,将非最高位置为0,再判断最高位是否为1。

当然该功能还有更好的办法,暂且不表。

优先级有疑问可参考下表。

相关文章
让用户输入x的值,如果x的值如果小于1,y=x,x如果大于等于1并且小于10,y=2x。。。 // x x < 1 // y={ 2X 1<=x
让用户输入x的值,如果x的值如果小于1,y=x,x如果大于等于1并且小于10,y=2x。。。 // x x < 1 // y={ 2X 1<=x
108 0
输入一个整数,判断大于0小于0还是等于0
输入一个整数,判断大于0小于0还是等于0
103 0
|
4月前
判断最大值
【10月更文挑战第31天】判断最大值。
52 7
|
4月前
使用函数判断Armstrong 数
【10月更文挑战第24天】使用函数判断Armstrong 数。
29 7
怎样判断一个数是否为偶数
怎样判断一个数是否为偶数
139 0
判断一个数是否能被3或5整除
判断一个数是否能被3或5整除
203 0
判断一个数能否同时被4和5整除
判断一个数能否同时被4和5整除
118 0
判断数的奇偶性
判断数的奇偶性
116 0
变量等于0时的判断问题
变量等于0时的判断问题
106 0
08:判断一个数能否同时被3和5整除
08:判断一个数能否同时被3和5整除
199 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等