2的32次方为2147483648*2,0~(2147483648*2-1)这是32位机上无符号整数代表的范围。而32机的int范围为-2147483648~+2147483647

stackoverflow.com上有人提出这样一个问题:

if (-2147483648 > 0)
    std::cout << "true";
else
    std::cout << "false";

这将输出true,
而下面的程序会输出false:

if (int(-2147483648) > 0)
    std::cout << "true";
else
    std::cout << "false";

下面是对排名第一答案的翻译:

-2147483648不是一个“数”。实际上,-2147483648是一个表达式:一个正整数2147483648和一个一维运算符“-”。对于32位机,2147483648明显已经超过了int的范围。如果long int有“更大的范围”,编译器会自动的假定2147483648为long int型。(C++11的编译器会假定为long long int型)。这样才会得到用户想要的“负的2147483648”

然而很明显,如果long int和int一样,就不会存在“更大的范围”了。这样的话,2147483648溢出了,你的程序的行为是未定义的

所以,通常我们这样定义

#define INT_MIN (-2147483647 - 1)

而不是,看似更直接的定义

#define INT_MIN -2147483648

后者可能造成意想不到的结果

原文地址:http://stackoverflow.com/questions/14695118/2147483648-0-returns-true-in-c#

posted on 2015-05-25 15:50  J博士  阅读(1268)  评论(0编辑  收藏  举报