ecvt() 函数原型如下:
[C++] 纯文本查看 复制代码
#include <stdlib.h>
char *ecvt(double number, int ndigits, int *decpt, int *sign);
该函数可以将参数 number 所表示的浮点数转换为字符串;
第 2 个参数 ndigits 表示的是显示的位数,比如 3.14159,如果指定 ndigits 为 4,那么最后就只显示 3.141 ,共 4 位。
第 3 个参数 decpt 表示在返回值中小数点的位置,从左到右以 0 开始算起,比如 3.14159 被转换后该值为 1 ;又如 -1000.2578 转换后为 4 。
第 4 个参数表示原来的数是正数还是负数,如果是正数,那么该值为 0,否则为 1 。
测试代码:
[C++] 纯文本查看 复制代码 #include <stdio.h>
#include <stdlib.h>
int main()
{
double a = 3.1415;
double b = -1000.2578;
char *ptr;
int decpt, sign;
ptr = ecvt(a, 5, &decpt, &sign);
printf ("decpt = %d, sign = %d, a-string = %s\n", decpt, sign, ptr);
ptr = ecvt(b, 6, &decpt, &sign); /*这里发生四舍五入的转换*/
printf ("decpt = %d, sign = %d, a-string = %s\n", decpt, sign, ptr);
return 0;
}
运行输出:./ecvt
decpt = 1, sign = 0, a-string = 31415 /*注意输出结果是没有小数点的*/
decpt = 4, sign = 1, a-string = 100026
fcvt() 函数的原型是:
[C++] 纯文本查看 复制代码 #include <stdlib.h>
char *fcvt(double number, int ndigits, int *decpt, int *sign);
fcvt() 和 ecvt() 的一个不同的地方是第 2 个参数表示的是小数点后显示的位数,它的转换也是四舍五入的。
测试代码:
[C++] 纯文本查看 复制代码 #include <stdio.h>
#include <stdlib.h>
int main()
{
double a = 3.1415;
double b = -1000.2578;
char *ptr;
int decpt, sign;
ptr = fcvt(a, 3, &decpt, &sign);
printf ("decpt = %d, sign = %d, a-string = %s\n", decpt, sign, ptr);
ptr = fcvt(b, 2, &decpt, &sign);
printf ("decpt = %d, sign = %d, a-string = %s\n", decpt, sign, ptr);
return 0;
}
运行输出:./fcvt
decpt = 1, sign = 0, a-string = 3142
decpt = 4, sign = 1, a-string = 100026
使用这两个函数需要注意的是他们的返回值:两个函数的返回值都是一个字符串指针,并且这个字符串被声明为静态(static),如果再次调用 ecvt() 或 fcvt() ,那么这个字符串的内容将会被覆盖。 |