关于C语言类型扩展的问题,经常被大家忽略,因为这是一个很隐秘的问题,请看下文:
void func(void)
{
int i=1;
unsigned char c1 = 1;
signed char c2 = -1;
if(c2 > i)
dprintf("\r\n -1 > 1");
else
dprintf("\r\n -1 <= 1");
if(c2 > c1)
dprintf("\r\n -1 > 1");
else
dprintf("\r\n -1 <= 1");
}
实际运行结果会是多少呢?
-1 > 1
-1 > 1
这是问什么呢? 很明显-1<1, 难道是打印有问题吗?还是这是C的一个BUG? 其实这是自己留下的一个隐患。
谨记:在C语言中,当两种不同类型之间运算时,低字节长度类型会向高自己长度类型转换,有符号会向无符号类型转换。
拿上例来说,当C2与i进行比较时,由于C2是有符号8位,i是无符号32位(int长度与机器类型有关,在32位机器中,int表示为32位),根据C语言的规则,c2被转换成32位,即-1的补码,故会得出-1>1的结论。
而后面一个-1<1的情况就不用说了吗?根据C规则,c2转化成无符号8位整数,即255,255当然大于1了,所以大家就会明白为什么-1>1了吧!(注:打印出的信息并没有错,虽然完全误导了程序员,但是这些都是因为自己给自己留下来的隐患)。
看了这篇文章之后,以后再编写程序时我们是否都应该多留一个心眼呢? 哈哈
作者:tdyichen1314
(现从事LED行业,专注于户外大型LED显示屏控制系统的研发,希望与大家一起交流,共同进步)
邮箱: