isnormal
来自 cppreference.cn
定义于头文件 <math.h> |
||
#define isnormal(arg) /* 实现定义 */ |
(自 C99) | |
确定给定的浮点数 arg 是否为正规,即既非零、次正规、无限,亦非 NaN
。此宏返回一个整数值。
FLT_EVAL_METHOD 被忽略:即使实参以超出其类型的范围和精度求值,它首先被转换为其语义类型,且分类基于该类型。
内容 |
[编辑] 参数
arg | - | 浮点数值 |
[编辑] 返回值
若 arg 为正规则为非零整数值,否则为 0。
[编辑] 示例
运行此代码
#include <float.h> #include <math.h> #include <stdio.h> int main(void) { printf("isnormal(NAN) = %d\n", isnormal(NAN)); printf("isnormal(INFINITY) = %d\n", isnormal(INFINITY)); printf("isnormal(0.0) = %d\n", isnormal(0.0)); printf("isnormal(DBL_MIN/2.0) = %d\n", isnormal(DBL_MIN / 2.0)); printf("isnormal(1.0) = %d\n", isnormal(1.0)); }
输出
isnormal(NAN) = 0 isnormal(INFINITY) = 0 isnormal(0.0) = 0 isnormal(DBL_MIN/2.0) = 0 isnormal(1.0) = 1
[编辑] 参考文献
- C23 标准 (ISO/IEC 9899:2024)
- 7.12.3.5 isnormal 宏 (p: TBD)
- C17 标准 (ISO/IEC 9899:2018)
- 7.12.3.5 isnormal 宏 (p: TBD)
- C11 标准 (ISO/IEC 9899:2011)
- 7.12.3.5 isnormal 宏 (p: 237)
- C99 标准 (ISO/IEC 9899:1999)
- 7.12.3.5 isnormal 宏 (p: 217-218)
[编辑] 参见
(C99) |
分类给定的浮点数值 (函数宏) |
(C99) |
检查给定的数是否为有限值 (函数宏) |
(C99) |
检查给定的数是否为无限 (函数宏) |
(C99) |
检查给定的数是否为 NaN (函数宏) |
C++ 文档 关于 isnormal
|