C 语言库函数 - frexp()

返回上一级

C 语言标准库 <math.h> 函数 double frexp(double x, int *exponent) 把浮点数 x 分解成尾数和指数。返回值是尾数,并将指数存入 exponent 中。

所得的值是 x = mantissa * 2 ^ exponent

头文件

#include <math.h>

函数原型

下面是 frexp() 函数的原型

double frexp(double x, int *exponent)

参数

  • x : 要被计算的浮点值

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

返回值

该函数返回规格化小数。

  • 如果参数 x 不为零,则规格化小数是 x 的二次方,且它的绝对值范围从 1/2(包含)到 1(不包含)

  • 如果 x 为零,则规格化小数是零,且零存储在 exp 中。

范例

下面的范例演示了 frexp() 函数的用法

/**
 * file: main.c
 * author: 简单教程(www.twle.cn)
 *
 * Copyright © 2015-2065 www.twle.cn. All rights reserved.
 */

#include <stdio.h>
#include <math.h>

int main ()
{
   double x = 64, fraction;
   int e;

   fraction = frexp(x, &e);
   printf("x = %.2lf = %.2lf * 2^%d\n", x, fraction, e);

   return(0);
}

编译运行范例,输出结果如下

$ gcc main.c && ./a.out
x = 64.00 = 0.50 * 2^7

返回上一级

C 语言标准库

关于   |   FAQ   |   我们的愿景   |   广告投放   |  博客

  简单教程,简单编程 - IT 入门首选站

Copyright © 2013-2022 简单教程 twle.cn All Rights Reserved.