unsigned char te1,te2,te3
te1 = 0xff;
te2 = 0x00;
if(te2 == (~te1))
{
te3 = 1;
}
else
{
te3 = 2;
}
最后te3为多少?为什么?
//@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;
}
最后的te3位2.
因为if(te2 == (~te1))中 (te2 == (~te1)这个表达式为一个赋值操作, 这个表达式的值等于(~te1), 而te1为char型的0xff, 取反后,值为0.
那么就是 if(0), 所以te3最后走 te3=2;这个分支, 故最终te3的值为2.**
您好,我不同意上述的说法,if括号中跟的是一个判断的条件,双等号在C语言中怎么能是赋值的操作呢?故最后的te3=1……当然你也可以利用开发软件,后面加一条printf("%d",te3),直接看输出
~te1 把十六进制的te1装换成二进制的值然后在进行补位,因为0xff的二进制是11111111补位的结果是100000000(9位)超过了二进制的8位,他的十进制值为-256
而te2的十进制的值0,所以0和-256不相等 结果te3=2
上述有人对取反的解释是正确的,我利用代码做了一个测试,你看看结果……后续对于这种的处理你可以在多加入一个变量,这样就不会出现位数超过使得结果错误的问题了
很奇怪,我直接把~te1赋值给变量a,那么if( te2 == a)是正常的,我怀疑可能是强制类型转换的问题,具体懒得想了,猜测大概是~操作会强制类型转换,
而且你设置的是unsigned char,那么强制类型转换的时候却会转换成类似于有符号的?所以就会导致有问题,我把unsigned char换成char就没有类似的问题了
答案是1。计算机科学已把“字节”严格界定为8位,由于定义数据类型时,加上了无符号unsigned,故8位均为正数,16进制0xff就是二进制11111111,即8位全为1,~取反后,8位全为0,所以if判断肯定为真,故答案为1。
别纠结了 圳于琊 的这个答案说得很清楚了,要是还不懂去看看 原码 补码 反码