在此,仅谈谈自己的理解,如有错误,欢迎指正!谢谢!
在64位系统中,类型字节大小<4字节,按4字节对整型常数进行处理,因此
(1)对取值范围为[-128,128)的char类型赋最小值-128,处理如下
128 . 0x00 00 00 10 (原码 ,反码 ,补码)
采用一元负运算符“-”对其取反,操作为取反加1(~(128)+1)
128 取反为 0xFF FF FF 7F,加1为 0xFF FF FF 10
char类型取低字节 0x10 (补码)存放,显示时采用printf
char c = -128;//0x10
printf("%c\n",c);
printf函数按从右到左进行入栈操作,每次入栈4字节,若入栈元素为char或short等小于4个字节的类型,入栈时也占4字节。因此0x10实际入栈为 0xFF FF FF 10 (补码),这里按符号位进行了补全,按char类型截取低字节对照ASCII表显示相应符号,若按照int类型显示,则显示
0xFF FF FF 10 (补码)对应的原码 0x10 00 00 10 (原码),-128
printf("%d\n",c);//-128
(2)对取值范围为[-2147483648,2147483648)的int类型赋最小值-2147483648,处理如下
2147483648 ,0x10 00 00 00 (原码 ,反码 ,补码)
由于int类型最大值为2147483647,因此当整型常量大于此值,将其类型优化为unsigned int (即取消符号位)
同样采用一元负运算符“-”对其取反,操作为取反加1
2147483648 取反仍为 0x10 00 00 00
因此产生了错误“一元负运算符应用于无符号类型,结果仍为无符号类型”
因为不报错会产生如下情况
int a = -2147483648;//实际上值为2147483648
if(5 > a){//按赋值意图将,5大于a,此处为true,但实际情况是5 < a,此处为false
...;
}