C语言INT_MIN定义的问题

关于c语言INT_MIN定义的问题

最近看到一段代码

1
2
#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。

写了一段代码验证

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#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));
}

运行结果为

1 < tmin
1 >INT_MIN
4

补充:

CSAPP的补充材料waside-tmin.pdf

上面的例子说明了不同格式字面值在C90和C99下面的类型确定的规则,C90 32位下类型为unsigned,就会产生上面程序的结果。

对于这种会产生不同行为的代码最好避免.

打赏
  • 版权声明: 本博客所有文章除特别声明外,均采用 Apache License 2.0 许可协议。转载请注明出处!
  • © 2015-2024 RivenZoo
  • Powered by Hexo Theme Ayer
  • PV: UV:

请我喝杯咖啡吧~

支付宝
微信