zoukankan      html  css  js  c++  java
  • 【译】为什么这样宏定义#define INT_MIN (-2147483647

    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#

  • 相关阅读:
    lntelliJ IDEA 皮肤设置
    Maven安装与配置
    lntelliJ IDEA 使用 Maven 与 每次新建项目都需要重新配置的解决方案
    Spring Boot 扫描机制说明
    Spring Boot Filter 使用指南
    Gradle构建CAS4.2.7爬坑指南
    Java的垃圾回收
    final与static
    angular directive自定义指令
    ui-router
  • 原文地址:https://www.cnblogs.com/jacklu/p/4528069.html
Copyright © 2011-2022 走看看