C语言中某些隐式转换会有意想不到的结果
代码
#include <stdio.h>
#include <stdlib.h>
int array[] = {
23, 34, 12, 17, 204, 99, 16
};
#define TOTAL_ELEMENTS (sizeof(array) / sizeof(array[0]))
int main() {
int d = -1, x;
if (d <= TOTAL_ELEMENTS) // 改为 d <= (int)TOTAL_ELEMENT即可
printf("-1 <= TOTAL_ELEMENTS\n");
else
printf("-1 > TOTAL_ELEMENTS\n");
}
输出
-1 > TOTAL_ELEMENTS
原因
TOTAL_ELEMENTS所定义的值是unsigned int类型(sizeof()的返回类型是无符号数)。if语句在signed int和unsigned int之间测试相等性,所以d被升级为unsigned int类型,-1转换为unsigned int的结果是一个非常大的正整数,致使表达式的值为假。
建议
尽量使用int类型,这样不用担心升级混合类型的复杂细节。只有在使用位段和二进制掩码时,才可以使用无符号数。在表达式中使用强制类型转换,使操作数均为符号数或者无符号数,这样不必由编译器来选择结果的类型。