在c++中浮点表示依赖于编译器

Is floating point representation compiler-dependent in C++?

本文关键字:表示 依赖于 编译器 c++      更新时间:2023-10-16

问题在标题中。我交付给客户的软件似乎有不同的行为,这取决于某些参数是作为整数传递还是作为浮点数传递。我用MinGW为我的客户构建了一个DLL,他将其集成在他的Visual Studio项目中,该项目使用了其他一些编译器(不知道是哪个,我猜是VS的标准编译器)。

会不会是他和我用不同的方式来表示浮点数呢?

谢谢你的提醒,查尔斯。

是的,浮点表示依赖于编译器。

理论上,您可以使用std::numeric_limits来确定表示的主要方面,例如它是IEEE 754,或者它是二进制还是十进制。

在实践中,除了内存布局,你不能依赖它,因为在主编译器g++中,浮点运算的语义受到优化选项的强烈影响(例如,NaN是否与自身相等)。

。实际上,它不仅依赖于编译器,还依赖于选项。

令人高兴的是,给定平台的编译器通常会符合该平台的浮点标准内存布局,例如Windows中的IEEE 754(该标准起源于PC平台)。因此,浮点值在c++和Visual c++之间进行交换时,通常应该可以正常工作。一个例外是,g++ long double映射到80位IEEE 754,而Visual c++它映射到普通的double,即64位,并且可以想象是什么给你带来麻烦。