-O1 / 2/3 with -std = c 1y / 11/98 – 如果包含我收到错误:’_hypot’未在此范围中声明

前端之家收集整理的这篇文章主要介绍了-O1 / 2/3 with -std = c 1y / 11/98 – 如果包含我收到错误:’_hypot’未在此范围中声明前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我刚刚使用mingw-get-setup更新了MinGW,我无法构建包含< cmath>如果我用-std = c 1y使用大于-O0的任何标题. (我也试过c 11和c 98)我收到像这样的错误
g++.exe -pedantic-errors -pedantic -Wextra -Wall -std=c++1y -O3  -c Z:\Projects\C++\L6\src\events.cpp -o obj\src\events.o
In file included from z:\lander\mingw\lib\gcc\mingw32\4.8.1\include\c++\cmath:44:0,from Z:\Projects\C++\L6\src\utils.h:4,from Z:\Projects\C++\L6\src\events.cpp:10:
z:\lander\mingw\include\math.h: In function 'float hypotf(float,float)':
z:\lander\mingw\include\math.h:635:30: error: '_hypot' was not declared in this scope
 { return (float)(_hypot (x,y)); }

我身边有什么问题吗?
或者在mingw repo版本被检测到?如果是这样,这个头部是否有任何快速修复?

解决方法

为了避免任何进一步的猜测,以及使用#if 0的彻底的坏建议,请从MinGW项目的贡献者的角度给出权威的答案.

是的,MinGW.org的include / math.h实现确实在它的inline实现中有一个缺陷(float,float);当编译C时,会引发错误,其中包含受影响的头(如果包含cmath),并指定导致__STRICT_ANSI__定义的任何编译器选项(如–std = c …的情况) OP指出的选项).适当的解决方案不是封闭一部分math.h文件,而是使用#if 0或其他方式,但是要纠正破坏的infp(float,float)的内联实现;只需从内联引用_hypot(float,float)中删除虚假的引导下划线,其返回值将被转换为浮点型返回类型就足够了.

或者,在编译器选项中替换等效的-std = gnu … for -std = c …可以避免该错误,并可能提供合适的解决方法.

FWIW,我并不满意MinGW.org目前的hypotl(long double,long double)的实现;纠正这两个问题是在我的下一个版本的MinGW运行时的打孔列表,但ATM,我没有时间致力于准备这个.

更新

MinGW.org运行时库(当前为mingwrt-3.22.4,但自3.22版本以来已修复)的现有版本中不再存在此错误.如果您使用的任何旧版本(包括任何严重破坏的4.x版本)都应升级.

猜你在找的C&C++相关文章