以来来说,char 等同于 signed char。但不同于unsigned char。
二者之间的区别在于能表达的范围:
char [-128, 127]
unsigned char [0, 255]
因为char是8bit的,而一般系统下的int通常都是32bit,所以在只需要小空间的整型变量的时候,常会用char来代替。(比如图像处理中的RGB)
这样子的话,定义
char a = 200;
unsigned char b = 200;
二者在内存上都是 [1100 1000]
但当你printf出来时候,
a: -56
b: 200
这是重点!
因为对于(signed) char a= 200,要进行符号位拓展。(补码与原码)
所以[1100 1000]有符号数的原码等于(非符号位减一,取反)[0011 1000] = -56。
本文解释了char和unsignedchar的区别,包括它们的表示范围、内存占用和输出表现。通过对比,展示了char作为8位整型变量在不同场景的应用,如图像处理中使用RGB颜色值。同时阐述了char作为带符号数时的符号位拓展原理。

1352

被折叠的 条评论
为什么被折叠?



