下面根据一道题来详细说说无符号整型运算,在这之前大家要先了解一下数据是如何在内存中存储的,参考我之前写的这篇博客:深度剖析数据在内存中的存储_crazy__xieyi的博客-CSDN博客
例题:
下面程序执行结果为
int main() { unsigned char a = 200; unsigned char b = 100; unsigned char c = 0; c = a + b; printf(“%d %d”, a+b,c); return 0; }
首先我们应该知道char的范围是-128-127; unsigned char 的范围是0-255;
unsigned char a = 200;
00000000 00000000 00000000 11001000
11001000 -a 截断
unsigned char b = 100;
00000000 00000000 00000000 01100100
01100100 - b 截断
下面我们要注意的是在进行c=a+b的运算时,是要进行整型提升的,所以
a 00000000 00000000 00000000 11001000
b 00000000 00000000 00000000 01100100
a+b 00000000 00000000 00000001 00101100
00101100-c 截断
又因为C的类型还是unsigned的,发生截断,所以结果为300 44。