最近看到一段代码html
#define INT_MAX 2147483647 #define INT_MIN (-INT_MAX - 1)
INT_MIN的值应该为 -2147483648,为何不直接定义呢?因而搜索了一下,参考了Jack47的blog:C语言中TMin的写法这篇文章。app
我的理解为C语言在处理程序中常量时,符号-
和后面的值是分开处理的,先处理字面值,而后将-
做为一元运算符。处理字面值的时候会决定这个常量的类型,基本的规则是选能容纳字面值的最小类型。如32位系统,2147483648这个值决定为unsigned int
,若是使用#define INT_MIN (-2147483648)
这个定义,INT_MIN类型为unsigned int
。ide
写了一段代码验证code
#include <stdio.h> #define INT_MAX 2147483647 #define INT_MIN (-INT_MAX - 1) // TMIN is unsigned int #define TMIN (-2147483648) int main(){ int i = 1; if (i > TMIN) printf("%d > tmin\n", i); else printf("%d < tmin\n", i); if (i > INT_MIN) printf("%d >INT_MIN\n", i); printf("%d\n",sizeof(TMIN)); }
运行结果为htm
1 < tmin 1 >INT_MIN 4
补充:blog
CSAPP的补充材料waside-tmin.pdfget
上面的例子说明了不一样格式字面值在C90和C99下面的类型肯定的规则,C90 32位下类型为unsigned,就会产生上面程序的结果。io
对于这种会产生不一样行为的代码最好避免.pdf