c++ - 无法在 C++ 中将 64 位数字分配给 64 位最小值

标签 c++ 64-bit

我是 C++ 的新手,如果这听起来像一个愚蠢的问题,我很抱歉。我正在尝试将 64 位最小值 (-9223372036854775808) 分配给 int64_t(来自 cstdint),但是我收到了当前的错误消息:

main.cpp:5:27: warning: integer literal is too large to be represented in a signed integer type, interpreting as unsigned [-Wimplicitly-unsigned-literal]
int64_t int_64_min = -9223372036854775808;
代码如下:
#include <iostream>
#include <cstdint>

int main() {
    int64_t int_64_min = -9223372036854775808;
    std::cout << int_64_min << std::endl;
    std::cout << INT64_MIN << std::endl;
    return 0;
}
我错过了一些明显的东西吗?

最佳答案

这就是为什么INT_MIN宏系列通常定义为 -INT_MAX - 1在 2 的补码平台上(从 C++20 开始几乎无处不在和强制)。
C++ 中没有负字面量这样的东西:只是正数的一元否定产生编译时可评估的常量表达式。9223372036854775808太大而无法放入 64 位有符号整数类型,因此否定它并分配给有符号 64 位整数类型的行为是实现定义的。
写作 -9223372036854775807 - 1可能是您的 C++ 标准库实现所做的。如果我是你,我会用 INT64_MIN直接或 std::numeric_limits<std::int64_t>::min() .

关于c++ - 无法在 C++ 中将 64 位数字分配给 64 位最小值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64578042/

相关文章:

64-bit - 自动工具可以创建多平台的生成文件

sharepoint - 32 位进程不支持 Microsoft SharePoint。请验证您是否在 64 位可执行文件中运行

c# - 在 Windows 8 Metro Windows Store 应用程序中合并声音文件音频和记录

c++ - 访问 gdb 在 C++ 中看到的程序信息

java - 在 C++ 中使用 Java JAR 库

c++ - 将 unsigned int 的指针传递给 long int 的指针

assembly - 标记的平均字节数

android - 将 Android NDK make 文件重构为模块

c++ - 为什么同一内存位置同时保存不同的值?

c++ - 如何在 Windows 7 64 位下使用 AddMonitor() 添加 redmonnt.dll