| 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 • 浮点数异常处理
|
|
|
|