谁能向我解释一下,如果初始化程序可能导致信息丢失,为什么编译器允许初始化内置类型的变量?
例如 C++ Primer,第 5 版说,如果初始化程序可能导致信息丢失,编译器不会让我们列出内置类型的初始化变量。
a但我的编译器 gcc v 4.7.1在以下代码中成功初始化了变量:
long double ld = 3.1415926536;
int a{ld};
只是警告:在 {} [-Wnarrowing] 内将 'ld' 从 'long double' 缩小到 'int' 的转换。
初始化列表的特性之一是不允许缩小转换。但是语言定义不区分警告和错误;当代码格式错误时,它需要“诊断”,它被定义为来自一组实现定义的消息中的任何消息。警告满足此要求。这就是非标准扩展的机制:发出警告后,编译器可以自由地做它想做的任何事情,包括根据特定于实现的规则编译某些东西。
您可以设置编译器标志以将所有警告标记为错误。在这种情况下,只有它会阻止你这样做。否则只会是警告。
这个问题最近出现了。使用 gcc-4.7 命令行开关打开所需的行为:
g++ -Werror=narrowing ...