檢查C 中的IEEE 754 浮點標準
確定C 編譯器是否遵循IEEE 754 浮點標準通常透過以下方式完成編譯器定義。然而,用於 C 的技術可能不會直接適用於 C 。
C 特定方法
幸運的是,C 提供了一種簡單的方法來使用numeric_limits 完成此檢查class:
std::numeric_limits::is_iec559;
如果編譯器使用IEEE 754,則此表達式的計算結果為true,否則為false。可以對float 類型執行類似的檢查:
std::numeric_limits::is_iec559;
std::numeric_limits
#include
int main() {
// Check for IEEE 754 compliance by checking for a finite number of float exponents.
if (std::numeric_limits::max_exponent == std::numeric_limits::max()) {
// Compiler uses IEEE 754.
} else {
// Compiler does not use IEEE 754.
}
}
#include
int main() {
// 透過檢查有限數量的浮點指數來檢查 IEEE 754 合規性。
if (std::numeric_limits
此方法依賴 IEEE 754 定義浮點數的特定指數範圍。如果編譯器的最大指數與整數的最大大小匹配,則很可能遵循 IEEE 754。
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3