错误83错误C2398:从'double'转换为'float'需要缩小转换

问题描述 投票:8回答:4

我发现了许多关于此错误的帖子,但我可以找到如何克服它。这是触发错误的代码:

void main(){
    float f{1.3};
}

为什么在initialize-list中没有像任何其他变量那样发生转换?例如,这很顺利:

float f = 1.3;
c++ c++11 casting floating-point compiler-bug
4个回答
12
投票

您已经评论过使用1.3会给编译器带来错误。这意味着你发现了编译器错误。标准很清楚,这不是一个缩小的转换,所以应该允许它。

引用N4140(大致是C ++ 14):

8.5.4列表初始化[dcl.init.list]

缩小转换是隐式转换

[...]

- (7.2)从long doubledoublefloat,或从doublefloat,除非源是常量表达式,转换后的实际值在可以表示的值范围内(即使它不能完全表示) ), 要么

[...]

你的1.3是在float范围内的常数表达式。

我建议将此报告给Microsoft,假设它已经不是已知问题。不幸的是,只是升级Visual Studio不会解决这个问题。我可以在VS2015中重现这个问题。


3
投票

使用'f'后缀强制它浮动可以避免缩小转换。以下作品..

float f{1.3f}

但我同意编译器应该照顾它..(根据@hvd引用的标准)


0
投票

由于它是C ++,不要使用c风格的强制转换,请尝试:

 static_cast<float>(std::abs(...))

0
投票

这可能是一个错误或其他什么。请改用:

float f;
f=1.3;
© www.soinside.com 2019 - 2024. All rights reserved.