关于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

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。