fpclassify
来自cppreference.com
在标头 <math.h> 定义 | ||
#define fpclassify(arg) /* 由实现定义 */ | (C99 起) | |
归类浮点数 arg 到下列类别中:零、非正规、正规、无穷大、NaN 或实现定义类别。该宏返回整数。
忽略 FLT_EVAL_METHOD:即使以多于实参类型的范围和精度对它求值,首先仍将它转换到其语义类型,然后基于该类型分类:正规的 long double
值可能在转换到 double 时变为非正规,而在转换到 float 时变为零。
目录 |
[编辑]参数
arg | - | 浮点数 |
[编辑]返回值
指明 arg 类别的 FP_INFINITE、FP_NAN、FP_NORMAL、FP_SUBNORMAL、FP_ZERO 或实现定义类型之一。
[编辑]示例
运行此代码
#include <float.h>#include <math.h>#include <stdio.h> constchar*show_classification(double x){switch(fpclassify(x)){caseFP_INFINITE:return"Inf";caseFP_NAN:return"NaN";caseFP_NORMAL:return"正规";caseFP_SUBNORMAL:return"非正规";caseFP_ZERO:return"零";default:return"未知";}}int main(void){printf("1.0/0.0 为 %s\n", show_classification(1/0.0));printf("0.0/0.0 为 %s\n", show_classification(0.0/0.0));printf("DBL_MIN/2 为 %s\n", show_classification(DBL_MIN/2));printf("-0.0 为 %s\n", show_classification(-0.0));printf("1.0 为 %s\n", show_classification(1.0));}
输出:
1.0/0.0 为 Inf 0.0/0.0 为 NaN DBL_MIN/2 为 非正规 -0.0 为 零 1.0 为 正规
[编辑]引用
- C23 标准(ISO/IEC 9899:2024):
- 7.12.3.1 The fpclassify macro (第 TBD 页)
- C17 标准(ISO/IEC 9899:2018):
- 7.12.3.1 The fpclassify macro (第 TBD 页)
- C11 标准(ISO/IEC 9899:2011):
- 7.12.3.1 The fpclassify macro (第 235 页)
- C99 标准(ISO/IEC 9899:1999):
- 7.12.3.1 The fpclassify macro (第 216 页)
[编辑]参阅
(C99) | 检查给定数是否具有有限值 (宏函数) |
(C99) | 检查给定数是否是无穷大 (宏函数) |
(C99) | 检查给定数是否为 NaN (宏函数) |
(C99) | 检查给定数是否正规 (宏函数) |
fpclassify 的 C++ 文档 |