关于C语言中无符号与有符号数之间运算问题
2016-04-20 10:45
330 查看
int array[] = {23, 34, 12, 17, 204, 99, 16}; #define TOTAL_ELEMENTS (sizeof(array)/sizeof(array[0])) int main(void) { int d = -1, x; /* ... */ if (d <= TOTAL_ELEMENTS - 2) x = array[d+1]; /* ... */ }
对于上述代码,if分支是不会被执行到的,即if表达式的值为假。
原因在于TOTAL_ELEMENTS所定义的值是unsigned int类型(因为sizeof()的返回类型是无符号数)。if语句在signed int和unsigned int之间测试相等性,所以d会被升级为unsigned int类型,-1转换为unsigned int的结果将是一个非常巨大的正整数,致使表达式的值为假。要解决这个问题,只要对TOTAL_ELEMENTS进行强制类型转换:
if (d <= (int)TOTAL_ELEMENTS - 2)
对于无符号类型:
尽量不要在代码中使用无符号类型,以免增加不必要的复杂性,尤其不要仅仅因为无符号数不存在负值而用它来表示数量。
尽量使用像int那样的有符号类型,这样在涉及升级混合类型的复杂细节时,不必担心边界情况。
只有在使用位段和二进制掩码时,才可以使用无符号数,应该在表达式中使用强制类型转换,使得操作数均为有符号数或者无符号数,这样不必由编译器来选择结果的类型。
相关文章推荐
- getchar()和getch()的区别
- 详解C语言中结构体的自引用和相互引用
- [C++]排序模板(含C++模板代码)
- C++中的基本知识点
- C++ STL stack queue 的使用函数
- C语言100个经典的算法
- eclipse 开发C/C++自动补全
- 根据某一分隔符分隔字符串
- Sizeof与Strlen的区别与联系
- 讨论: 字符串数组与字符串指针数组
- [c++]一道算法题的思考
- C/C++中产生随机数
- 第4周 C语言及程序设计提高例程-8 函数的声明、定义和调用
- 第4周 C语言及程序设计提高例程-7 返回指针的函数
- C++的三种继承方式
- c++中的转码函数
- c++中查询硬件与系统信息api
- MD5算法的C++实现
- 快速的制作一张简单报表
- c/c++ 读取当前时间