C语言中的gcvt和ecvt以及fcvt函数 对比分析C语言中的gcvt()和ecvt()以及fcvt()函数
人气:1想了解对比分析C语言中的gcvt()和ecvt()以及fcvt()函数的相关内容吗,在本文为您仔细讲解C语言中的gcvt和ecvt以及fcvt函数的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:C语言,字符串,转换,下面大家一起来学习吧。
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.45 b 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; /* scientific notation */ ndig = 5; string = fcvt(value,ndig,&dec,&sign); printf("string = %s dec = %d sign = %d\n", string, dec, sign); return 0; }
输出结果如下:
加载全部内容