(原创)关于C语言类型扩展的隐患

关于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显示屏控制系统的研发,希望与大家一起交流,共同进步)

邮箱:495567585@qq.com

        td.logic@hotmail.com

 

posted on 2012-04-03 12:10  tdyizhen1314  阅读(603)  评论(1编辑  收藏  举报

导航