关于c语言INT_MIN定义的问题
关于c语言INT_MIN定义的问题
最近看到一段代码
#define INT_MAX 2147483647
#define INT_MIN (-INT_MAX - 1)
INT_MIN的值应该为 -2147483648,为什么不直接定义呢?于是搜索了一下,参考了Jack47的blog:C语言中TMin的写法这篇文章。
个人理解为C语言在处理程序中常量时,符号-
和后面的值是分开处理的,先处理字面值,然后将-
作为一元运算符。处理字面值的时候会决定这个常量的类型,基本的规则是选能容纳字面值的最小类型。如32位系统,2147483648这个值决定为unsigned int
,如果使用#define INT_MIN (-2147483648)
这个定义,INT_MIN类型为unsigned int
。
写了一段代码验证
#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
", i);
else
printf("%d < tmin
", i);
if (i > INT_MIN)
printf("%d >INT_MIN
", i);
printf("%d
",sizeof(TMIN));
}
运行结果为
1 < tmin
1 >INT_MIN
4
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。