u014043703
磊朱
2017-07-18 05:41
采纳率: 100%
浏览 2.4k
已采纳

C语言问题,if条件里面按位取反

unsigned char te1,te2,te3

te1 = 0xff;
te2 = 0x00;

if(te2 == (~te1))
{
te3 = 1;
}
else
{
te3 = 2;
}

最后te3为多少?为什么?

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

8条回答 默认 最新

  • u014068781
    ZZB博客 2017-07-18 08:54
    已采纳

    //@author Mr zhang zhenyuya@163.com

    #include

    int main() {
    unsigned char te1,te2,te3;
    te1 = 0xff;
    te2 = 0x00; //te2二进制:00000000
    if(te3 == (~te1)){
    te3 = 1;
    }
    else{
    te3 = 2;
    }
    printf("%d",te3);//输出:2
    printf("%u",(char)(~te1));//无符号char 输出是:0
    //无符号char 输出解析:
    //te1:0000 0000 0000 0000 0000 0000 1111 1111
    //~te1:1111 1111 1111 1111 1111 1111 0000 0000
    //~te1强制转换char:0000 0000 所以输出为0
    printf("%u",(~te1)); //无符号 输出是:4294967040
    //无符号 输出解析:
    //te1:0000 0000 0000 0000 0000 0000 1111 1111
    //~te1:1111 1111 1111 1111 1111 1111 0000 0000
    //~te1=二进制1111 1111 1111 1111 1111 1111 0000 0000=4294967040
    printf("%d",(~te1)); //有符号int 输出是:-256
    //有符号 输出解析:
    //te1:0000 0000 0000 0000 0000 0000 1111 1111
    //~te1:1111 1111 1111 1111 1111 1111 0000 0000
    //由于:~te1开头为1 是负数 补码输出
    //~te1=1000 0000 0000 0000 0000 0000 1111 1111 + 1 = -256

    if(-256 == (~te1)){
        te3 = 1;
    }
    else{
        te3 = 2;
    }
    printf("%d",te3);//输出:1
    //说明在条件语句中(~te1)是按有符号输出 然后在做比较。
    
    return 0;
    

    }

    点赞 评论
  • bcm56504
    嵌入式技术交流 2017-07-18 06:06

    最后的te3位2.

    因为if(te2 == (~te1))中 (te2 == (~te1)这个表达式为一个赋值操作, 这个表达式的值等于(~te1), 而te1为char型的0xff, 取反后,值为0.
    那么就是 if(0), 所以te3最后走 te3=2;这个分支, 故最终te3的值为2.**

    点赞 评论
  • smile_w
    smile_w 2017-07-18 06:17

    您好,我不同意上述的说法,if括号中跟的是一个判断的条件,双等号在C语言中怎么能是赋值的操作呢?故最后的te3=1……当然你也可以利用开发软件,后面加一条printf("%d",te3),直接看输出

    点赞 评论
  • strutce
    丵鹰 2017-07-18 06:38

    ~te1 把十六进制的te1装换成二进制的值然后在进行补位,因为0xff的二进制是11111111补位的结果是100000000(9位)超过了二进制的8位,他的十进制值为-256
    而te2的十进制的值0,所以0和-256不相等 结果te3=2

    点赞 评论
  • smile_w
    smile_w 2017-07-18 06:45

    上述有人对取反的解释是正确的,我利用代码做了一个测试,你看看结果……后续对于这种的处理你可以在多加入一个变量,这样就不会出现位数超过使得结果错误的问题了图片说明

    点赞 评论
  • wjlwangluo
    上杉绘梨衣- 2017-07-18 08:04

    很奇怪,我直接把~te1赋值给变量a,那么if( te2 == a)是正常的,我怀疑可能是强制类型转换的问题,具体懒得想了,猜测大概是~操作会强制类型转换,
    而且你设置的是unsigned char,那么强制类型转换的时候却会转换成类似于有符号的?所以就会导致有问题,我把unsigned char换成char就没有类似的问题了

    点赞 评论
  • suwei80286
    苏为斌 2017-07-18 08:36

    答案是1。计算机科学已把“字节”严格界定为8位,由于定义数据类型时,加上了无符号unsigned,故8位均为正数,16进制0xff就是二进制11111111,即8位全为1,~取反后,8位全为0,所以if判断肯定为真,故答案为1。

    点赞 评论
  • lzl_Avery
    lzl_Avery 2017-07-18 11:52

    别纠结了 圳于琊 的这个答案说得很清楚了,要是还不懂去看看 原码 补码 反码

    点赞 评论

相关推荐