首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >位Testing.Counting位

位Testing.Counting位
EN

Stack Overflow用户
提问于 2019-11-23 03:32:11
回答 1查看 40关注 0票数 1

为什么它打印47(00101111)的位数6是1。从右侧开始从1开始计数?

代码语言:javascript
复制
 #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;
    }
EN

回答 1

Stack Overflow用户

发布于 2019-11-23 03:38:46

与不等运算符!=相比,按位AND运算符&的优先级较低。所以这就是:

代码语言:javascript
复制
47&mask1!=0

与以下内容相同:

代码语言:javascript
复制
47&(mask1!=0)

添加括号,如下所示:

代码语言:javascript
复制
(47&mask1)!=0

你就会得到预期的结果。请确保对mask2执行相同的检查。

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59000645

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档