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

unsigned char te1,te2,te3

te1 = 0xff;
te2 = 0x00;

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

最后te3为多少?为什么?

8个回答

//@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;

}

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

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

smile_w
smile_w 回复磊朱: 这个问题就体现在取反的内部实现过程中
3 年多之前 回复
u014043703
磊朱 我在嵌入式平台下测试过了上面这一段,结果是te3 = 2;所以比较疑惑
3 年多之前 回复

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

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

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

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

最后的te3位2.

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

bcm56504
嵌入式技术交流 回复磊朱: 卧槽,看错了,
3 年多之前 回复
u014043703
磊朱 回复smile_w: 我在嵌入式平台下测试过了上面这一段,结果是te3 = 2;所以比较疑惑
3 年多之前 回复
smile_w
smile_w 回复磊朱: 两个的等号在C语言中是判断等于的意思,并不是所谓赋值
3 年多之前 回复
u014043703
磊朱 (te2 == (~te1)为什么不是一个判断语句而是一个赋值操作?
3 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐