对比分析C语言中的gcvt()和ecvt()以及fcvt()函数

这篇文章主要介绍了对比分析C语言中的gcvt和ecvt以及fcvt函数,都是将数字转化为字符串,注意其之间的功能区别,需要的朋友可以参考下
 

gcvt()函数:
头文件:#include <stdlib.h>

定义函数:

1
char *gcvt(double number, size_t ndigits, char *buf);

函数说明:gcvt()用来将参数number 转换成ASCII 码字符串,参数ndigits 表示显示的位数。gcvt()与ecvt()和fcvt()不同的地方在于,gcvt()所转换后的字符串包含小数点或正负符号。若转换成功,转换后的字符串会放在参数buf 指针所指的空间。

返回值:返回一字符串指针,此地址即为buf 指针。

范例

1
2
3
4
5
6
7
8
9
10
11
#include <stdlib.h>
main(){
  double a = 123.45;
  double b = -1234.56;
  char *ptr;
  int decpt, sign;
  gcvt(a, 5, ptr);
  printf("a value=%s\n", ptr);
  ptr = gcvt(b, 6, ptr);
  printf("b value=%s\n", ptr);
}

执行结果:

1
2
a value=123.45
b value=-1234.56

 

ecvt()函数:

  功 能:将双精度浮点型数转换为字符串,转换结果中不包括十进制小数点。

  用 法:

1
char *Ecvt(double value, int ndigit, int *decpt, int *sign);

  详细解释:Ecvt函数把一个双精度浮点数转换成一个字符串。value参数是要转换的浮点数。这个函数存储最多ndigit个数字值作为一个字符串,并添加一个空数字符('\0'),如果value中的数字个数超过ndigit,低位数字被舍入。如果少于ndigit个数字,该字符串用0填充。

  只有数字才存储在该字符串中,小数点位置和value符号在调用之后从decpt和sign获取。decpt参数指出给出小数点位置的整数值, 它是从该字符串的开头位置计算的。0或负数指出小数点在第一个数字的左边。sign参数指出一个指出转换的数的符号的整数。如果该整数为0,这个数为正数,否则为负数。

  参 数:

  •   value:待转换的双精度浮点数。
  •   ndigit:存储的有效数字位数。
  •   *decpt:存储的小数点位置。
  •   *sign:转换的数的符号。

  返回值:

  •   char*:指向生成的字符串。

  备注:该函数的头文件是“stdlib.h”。


fcvt()函数

函数名:fcvt

功   能:把一个浮点数转换为字符串

头文件:

1
#include <stdlib.h>

原   型:

1
*fcvt(double value, int ndigit, int *decpt, int *sign);

参数说明:value是要转换的浮点数;ndigit是小数点后面的位数;*decpt表示小数点的位置;*sign表示符号,0为正数,1为负数。

实例代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#include <stdlib.h>
#include <stdio.h>
#include <conio.h>
   
int main(void)
{
  char *string;
  double value;
  int dec, sign;
  int ndig = 10;
  //clrscr();
  value = 9.876;
  string = fcvt(value, ndig, &dec, &sign);
  printf("string = %s dec = %d sign = %d\n", string, dec, sign);
  value = -123.45;
  ndig= 15;
  string = fcvt(value,ndig,&dec,&sign);
  printf("string = %s dec = %d sign = %d\n", string, dec, sign);
  value = 0.6789e5; /* scientific notation */
  ndig = 5;
  string = fcvt(value,ndig,&dec,&sign);
  printf("string = %s dec = %d sign = %d\n", string, dec, sign);
  return 0;
}

输出结果如下:

 

 

函数名称: gcvt 
函数原型: char * gcvt(double value,int ndec,char *buf) 
函数功能: 将数值value转换为长度为ndec的字符串,包含小数点。 
函数返回: 指向buf的指针 
参数说明: value-要转换的浮点数值,ndec-转换后的长度

函数名称: ecvt 
函数原型: char *ecvt(double value,int ndigIT,int *dec,int *sign) 
函数功能: 将浮点数转换为长度为ndigIT字符串,没有小数点,如果超过value的数字长度不补零。 
函数返回: 转换后的字符串指针 
参数说明: value-待转换底浮点数,ndigIT-转换后的字符串长度

函数原型: char *fcvt(double value,int ndigIT,int *dec,int *sign) 
函数功能: 将浮点数转换为长度为ndigIT字符串,没有小数点,如果超过value的数字长度将补零。 
函数返回: 转换后字符串指针 
参数说明: value-待转换底浮点数,ndigIT-转换后底字符串长度

#include <iostream>

using namespace std;

int main(int argc, char** argv)
{
    double d = 345.8736;
    int a=0, b=0, c = 5;

    char szBuff[20];

    gcvt(d, 15, szBuff);

    cout<<szBuff<<endl;

    cout<<ecvt(d, c, &a, &b)<<endl;

    cout<<fcvt(d, c, &a, &b)<<endl;

    return 0;
}
posted @ 2018-06-06 22:46  chenlife  阅读(1810)  评论(0)    收藏  举报