C++ Builder 串口控件 | C++ Builder 编程技巧 | C++ Builder 操作指南 | C++ Builder 参考手册 | 基础知识 | cfloat 浮点数 | cmath 数学函数 | cstdlib 标准库函数 | • atof, _ttof, _wtof | • _atold, _ttold, _wtold | • atoi, _ttoi, _wtoi | • atol, _ttol, _wtol | • _atoi64, _ttoi64, _wtoi64 | • strtod, _tcstod, wcstod | • strtof, _tcstof, wcstof | • strtold, _strtold, _tcstold, wcstold, _wcstold | • strtol, _tcstol, wcstol | • strtoll, _tcstoll, wcstoll | • strtoul, _tcstoul, wcstoul | • strtoull, _tcstoull, wcstoull | • itoa, _itot, _itow | • ltoa, _ltoa, _ltot, _ltow | • ultoa, _ultot, _ultow | • _i64toa, _i64tot, _i64tow | • _ui64toa, _ui64tot, _ui64tow | • ecvt, _ecvt | • fcvt, _fcvt | • gcvt, _gcvt | • abs, labs, llabs | • div, ldiv, lldiv | • div_t, ldiv_t, lldiv_t | • _rotl, _crotl, _lrotl | • _rotr, _crotr, _lrotr | • rand, _lrand | • srand | • random | • randomize | • mbstowcs | • mblen | • mbtowc | • mbtowc_cp | • wcstombs | • wctomb | • wctomb_cp | • swab, _swab | • _fullpath, _tfullpath, _wfullpath | • _makepath, _tmakepath, _wmakepath | • _splitpath, _tsplitpath, _wsplitpath | • getenv, _tgetenv, _wgetenv | • putenv, _putenv, _tputenv, _wputenv | • _searchenv, _tsearchenv, _wsearchenv | • _searchstr, _tsearchstr, _wsearchstr | • system, _tsystem, _wsystem | • abort | • atexit | • atexit_t | • exit, _exit | • abort_handler_s | • ignore_handler_s | • constraint_handler_t | • set_constraint_handler_s | • _argc | • _argv, _targv, _wargv; | • _environ, _tenviron, _wenviron | • EXIT_SUCCESS, EXIT_FAILURE | • _MAX_PATH, _MAX_DRIVE, _MAX_DIR, _MAX_FNAME, _MAX_EXT | • MB_CUR_MAX | • RAND_MAX, LRAND_MAX | System 字符串 | System 日期和时间 | System.Math.hpp 数学函数 | 其他数据类型 | VCL 基础类 | VCL 应用程序 | Pictures 图片 | Graphics 绘图 | Additional 控件 | System 控件 | A ~ Z 字母顺序排列的目录 | 网友留言/技术支持 |
|
gcvt, _gcvt - 把一个浮点数转成字符串,指定要保留几位有效数字,小数方式或科学计数法,当这些位有效数字无法用小数方式表达时,会变成科学计数法 |
gcvt, _gcvt:把一个浮点数转成字符串,指定要保留几位有效数字,小数方式或科学计数法,当这些位有效数字无法用小数方式表达时,会变成科学计数法
函数原型:
char *gcvt(double value, int ndec, char *buf); |
char *_gcvt(double value, int ndec, char *buf); |
头文件:
#include <cstdlib>
命名空间:
std
参数:
value:浮点数
ndec:有效位数,超过这个位数的数据进行四舍五入,不足位数不补 '0'
buf:保存转换的结果,必须能够容纳转换结果的字符串 + 结束符
返回值:
返回值:指向 buf 的指针;
buf:转换的结果
value |
ndec |
返回值 |
说明 |
123.45678 |
5 |
123.46 |
|
10 |
5 |
10 |
|
1.25 |
5 |
1.25 |
|
-0.987654321 |
5 |
-0.98765 |
|
-0.987654321 |
8 |
-0.98765432 |
|
-0.0625 |
8 |
-0.0625 |
|
0.001 |
8 |
0.001 |
|
-0.000012345678901 |
5 |
-1.2346e-05 |
使用科学计数法表示的 -1.2346×10-5 |
1234567890 |
5 |
1.2346e+09 |
使用科学计数法表示的 1.2346×109 |
-1234567890 |
5 |
-1.2346e+09 |
使用科学计数法表示的 -1.2346×109 |
例子:
void __fastcall TForm1::Button1Click(TObject *Sender)
{
double v = -0.000012345678901;
char buf[32];
UnicodeString s = gcvt(v, 5, buf);
Memo1->Lines->Add(L"保留 5 位有效数字:" + s);
} |
兼容性:
相关链接:
• atof • _atold • strtod • strtof • strtold • ecvt • fcvt • gcvt
• StrToFloat • StrToFloatDef • FloatToStr • FloatToStrF • FormatFloat
• _matherr • 浮点数异常处理
|
|
|
|