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

时间:2021-05-19

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

定义函数:

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

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

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

范例

#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);}

执行结果:

a value=123.45b value=-1234.56

ecvt()函数:

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

  用 法:

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

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

头文件:

#include <stdlib.h>

原 型:

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

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

实例代码:

#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; ndig = 5; string = fcvt(value,ndig,&dec,&sign); printf("string = %s dec = %d sign = %d\n", string, dec, sign); return 0;}

输出结果如下:

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章