计算指数。
语法
double exp(
double x
);
float exp(
float x
); // C++ only
long double exp(
long double x
); // C++ only
float expf(
float x
);
long double expl(
long double x
);
#define exp(z) // Requires C11 or later
参数
x
对自然对数底 e 求幂的浮点值。
返回值
exp 函数返回浮点参数的指数值,如果成功,则为 x。 也就是说,结果是 ex,其中 e 是自然对数的底。 在溢出时,该函数返回 INF(无限),在下溢时,exp 返回 0。
| 输入 | SEH 异常 | _matherr 异常 |
|---|---|---|
| ±静默 NaN, 不确定 | 无 | _DOMAIN |
| ± 无穷大 | INVALID |
_DOMAIN |
x ≥ 7.097827e+002 |
INEXACT+OVERFLOW |
OVERFLOW |
x ≤ -7.083964e+002 |
INEXACT+UNDERFLOW |
UNDERFLOW |
exp 函数具有使用流式处理 SIMD 扩展 2 (SSE2) 的实现。 有关使用 SSE2 实现的信息和限制,请参阅_set_SSE2_enable。
备注
C++ 允许重载,因此你可以调用采用 float 或 long double 参数的 exp 重载。 在 C 程序中,除非你使用 <tgmath.h> 宏来调用此函数,否则 exp 始终采用并返回 double。
如果使用 <tgmath.h> 中的 exp 宏,自变量的类型将确定选择哪个版本的函数。 有关详细信息,请参阅泛型类型数学。
默认情况下,此函数的全局状态范围限定为应用程序。 若要更改此行为,请参阅 CRT 中的全局状态。
要求
| 函数 | 必需的 C 标头 | 必需的 C++ 标头 |
|---|---|---|
| .- . | <math.h> |
<cmath> 或 <math.h> |
exp 宏 |
<tgmath.h> |
有关兼容性的详细信息,请参阅 兼容性。
示例
// crt_exp.c
#include <math.h>
#include <stdio.h>
int main( void )
{
double x = 2.302585093, y;
y = exp( x );
printf( "exp( %f ) = %f\n", x, y );
}
exp( 2.302585 ) = 10.000000