问题描述
- 程序求解:为什么i*-1中,不是先把-1转化为无符号数4294967295,然后再与i相乘?
-
程序如下:
#include < stdio.h >
int main()
{
unsigned int i=3;
printf("%u
",i*-1);
return 0;
}
程序的输出为4294967293,也就是-3对应的无符号值。
为什么i*-1中,不是先把-1转化为无符号数4294967295,然后再与i相乘?
解决方案
首先 i*-1,这么写是人难以理解的,
其次:
其实这结果 就是 4294967295*3的结果,不过截取低32Bits而已。
4294967295*3=12884901885 = 0x2FFFFFFFD
截取32Bits后=0xFFFFFFFD = 4294967293
解决方案二:
API LoadModule I was lood1
SPOJ GSS1 Can you answer these queries I
How I explained Design Patterns to my wife: Part 1
解决方案三:
这个明显是机内码的问题。-1就是‘1111111111111111111111111111111’,乘上三后‘11111111111111111111111111111101’(能保存长度限制),结果还是和-3一样
解决方案四:
哥们你的头文件是不是少了点东西
解决方案五:
隐式转换是把比较低级的转换成比较高级的。比如整型数乘浮点数,整型数默认转换成浮点数。
解决方案六:
头文件是不是少了东西 呢
时间: 2024-08-19 23:47:51