提取浮点型参数的指数值。

语法

double logb(
   double x
);
float logb(
   float x
); // C++ only
long double logb(
   long double x
); // C++ only
float logbf(
   float x
);
long double logbl(
   long double x
);
double _logb(
   double x
);
float _logbf(
   float x
);
#define logb(X) // Requires C11 or higher

参数

x
浮点值。

返回值

logb 返回 x 的无偏差指数值作为表示为浮点值的带符号整数。

备注

logb 函数提取浮点型参数 x 的指数值,类似于使用无限范围表示 x。 如果未使参数 x 非规范化,则将其视为已规范化。

由于 C++ 允许重载,因此你可以调用采用并返回 logbfloat 值的 long double 重载。 在 C 程序中,除非你使用 <tgmath.h> 宏来调用此函数,否则 logb 始终采用并返回 double

如果使用 <tgmath.h> 中的 logb 宏,自变量的类型将确定选择哪个版本的函数。 有关详细信息,请参阅泛型类型数学

输入 SEH 异常 _matherr 异常
± QNaN, IND _DOMAIN
± 0 ZERODIVIDE _SING

默认情况下,此函数的全局状态范围限定为应用程序。 若要更改此行为,请参阅 CRT 中的全局状态

要求

例程 必需的标头
_logb <float.h>
<math.h>
logb <tgmath.h>

有关兼容性的详细信息,请参阅 兼容性

C 运行时库的所有版本。

另请参阅

数学和浮点支持
frexp