将负的constdouble转换为unsigned结果为0而非常量double很好

我有这个代码:

#include <iostream>

int main() {
    double val = -400.0;
    const double constVal = -400.0;
    std::cout << val << std::endl;
    std::cout << static_cast<unsigned>(val) << std::endl;
    std::cout << constVal << std::endl;
    std::cout << static_cast<unsigned>(constVal) << std::endl;

    return 0;
}

当我运行它时,这是输出:

-400
4294966896
-400
0

为什么会发生这种情况?适量的谷歌搜索在这个问题上没有显示任何内容。

回答

从cppreference.com:

浮点类型的纯右值可以转换为任何整数类型的纯右值。小数部分被截断,即小数部分被丢弃。如果该值不能适合目标类型,则行为未定义(即使目标类型是无符号的,模运算也不适用)。如果目标类型是 bool,这是一个布尔转换(见下文)。

-400 不能放入unsigned,因此行为未定义。试图对任何类型的一致性进行推理都是无用的。

由于这是未定义的行为,编译器在这种情况下可以做任何它想做的事情。通常,他们会做任何使他们的(定义的)行为更容易编码的事情。尽管有流行的说法,编译器不太可能让恶魔从你的鼻子里飞出来,但人们不应该期待任何特别的行为。

  • If I was a betting man, I wouldn't bet on it shooting you. But if it WERE to shoot you, it would at least be standard compliant.
  • Just don't turn on the `-Woptimize-out-non-pedantic-programmers` flag in gcc and you'll be fine.

以上是将负的constdouble转换为unsigned结果为0而非常量double很好的全部内容。
THE END
分享
二维码
< <上一篇
下一篇>>