English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

C语言基础教程

C语言流程控制

Função do C

Array do C

Ponteiro do C

String do C

C语言结构体

C语言文件

C其他

C语言参考手册

C库函数frexp()的使用方法及示例

Biblioteca Padrão do C - <math.h>

C库函数 double frexp(double x, int *exponent) 将浮点数x分解为尾数和指数。返回值是尾数,并将指数存入 exponent 中。所得的值是 x = mantissa * 2 ^ exponent

声明

以下是frexp()函数的声明。

double frexp(double x, int *exponent)

参数

  • x  -- 要被计算的浮点值。

  • exponent  -- 指向一个对象的指针,该对象存储了指数的值。

返回值

该函数返回规范化小数。如果参数x不为零,则规范化小数是x的二次方,且它的绝对值范围从 1/2(包含)到 1(不包含)。如果x为零,则规范化小数是零,且零存储在exp中。

在线示例

以下示例演示了frexp()函数的用法。

#include <stdio.h>
#include <math.h>
int main ()
{
   double x = 2048, fraction;
   int e;
   
   fraction = frexp(x, &e);
   printf("x = %."2lf = %.2lf * 2^%d\n", x, fração, e);
   
   return(0);
}

Vamos compilar e executar o programa acima, o que produzirá o seguinte resultado:

x = 2048.00 = 0.50 * 2^12

Biblioteca Padrão do C - <math.h>