32位的int的最大值与最小值,最大值2的31次方-1====pow(2,31) - 1,最小值为负的2的31次方= -pow(2,31)ui
C语言中没有次幂的运算符,,,“^”是异或的运算符。
io
看个题:im
#include
int main()
{
unsigned int a=6;
int b=-20;
printf("%d\n",a+b);
(a+b)>6? puts(">6"):puts("<=6");
return 0;
}
语言
结果是:-14 >6di
意想不到吧?运算符
为何结果这样呢?return
原来有符号数和无符号数进行比较运算时(==,,<=,>=),有符号数隐式转换成了无符号数(即底层的补码不变,可是此数从有符号数变成了无符号数),好比上面 (a+b)>6这个比较运算,a+b=-14,-14的补码为1111111111110010。此数进行比较运算时,被当成了无符号数,它远远大于6,因此获得上述结果。底层
本身作个实验printf
uint32_t u32OS_CurTimestamp = 0 - 1;
int i32OS_TimesInterval = -pow(2,3);
(1) Printf("Test 1 stamp=%u,val=%d,val=%x!", u32OS_CurTimestamp , i32OS_TimesInterval , i32OS_TimesInterval);
(2) i32OS_TimesInterval = i32OS_TimesInterval - u32OS_CurTimestamp;
(3) Printf("Test 2 stamp=%x,val=%d,val=%x!", u32OS_CurTimestamp , i32OS_TimesInterval , i32OS_TimesInterval);
Test 1 stamp=4294967295,val=-8,val=FFFFFFF8!
Test 2 stamp=FFFFFFFF,val=-7,val=FFFFFFF9!
分析
i32OS_TimesInterval的初值为-8,u32OS_CurTimestamp的初值为FFFFFFFF,且一直没有改变。当运行第二条指令时,是有符号数与无符号数的运算,隐式转换为无符号数即为FFFFFFF8。而后FFFFFFF8-FFFFFFFF= FFFFFFF9,将FFFFFFF9转换为有符号数就是-7