與C 不同,C 需要特定的定義檢定來驗證編譯器是否遵守IEEE 754 標準,C 提供更直接的方法。 C 標準在 std 命名空間中包含 numeric_limits 類別。若要確定編譯器是否採用IEEE 754,只需如下存取靜態成員is_iec559:
<code class="cpp">std::numeric_limits<double>::is_iec559;</code>
或:
<code class="cpp">std::numeric_limits<float>::is_iec559;</code>
如果正在使用IEEE 754,則此表達式傳回true,並且
或者,按照Adam 的回答建議,您還可以採用另一種方法:
<code class="cpp">#include <iostream> #include <cmath> int main() { double d = -0.0; std::cout << (std::signbit(d) != std::signbit(-d)) << std::endl; return 0; }</code>
如果編譯器支援IEEE 754,則此程式碼輸出0;否則為false。否則,輸出 1.
以上是如何確定 C 編譯器是否遵循 IEEE 754 標準?的詳細內容。更多資訊請關注PHP中文網其他相關文章!