C语言中无符号数和有符号数相加问题

时间:2021-07-30 01:20:20

32位的int的最大值与最小值,最大值2的31次方-1====pow(2,31) - 1,最小值为负的2的31次方=    -pow(2,31)

C语言中没有次幂的运算符,,,“^”是异或的运算符。

看个题:

#include<stdio.h>
int main()
{
unsigned int a=6;
int b=-20;
printf("%d\n",a+b);
(a+b)>6? puts(">6"):puts("<=6");
return 0;
}

结果是:-14  >6

意想不到吧?

为什么结果这样呢?

原来有符号数和无符号数进行比较运算时(==,<,>,<=,>=),有符号数隐式转换成了无符号数(即底层的补码不变,但是此数从有符号数变成了无符号数),比如上面 (a+b)>6这个比较运算,a+b=-14,-14的补码为1111111111110010。此数进行比较运算时,被当成了无符号数,它远远大于6,所以得到上述结果。

自己做个实验

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