浮点-c++格式化具有自动精度的浮点
floating point - c++ formatting float with automatic precision
有没有一种标准的方法可以将C++中的浮点(或双精度(格式化为十进制,并具有足够的精度将其解析回相同的位?
也就是说,我希望1.F
是"1.0"
,2.002f
是"2.002"
。
对于十进制不精确的情况,可以接受另一种格式(科学或甚至十六进制浮点(。是否存在这种情况?
我所能找到的只是参考std::fixed
和std::setprecision
例如该链接。这些的精度是固定的。
谢谢。
我必须做很多事情,也就是说,你想做什么。我的解决方案是使用这样的东西:
char buf[32];
sprintf(buf, "%.15f", v);
TrimTrailingZeros(buf);
相关文章:
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 如何防止 c++ 在从浮点型转换为双精度型(不适用于 IO)时添加额外的小数?
- 正在将csv文件读取为双精度矢量
- 如何理解将半精度指针转换为无符号长指针和相关的内存对齐
- 我可以信任表示整数的浮点或双精度来保持精度吗
- 如何在C++中的同一函数中使用字符串和双精度
- 特征::矩阵<双精度,1,3> 结构类型函数中的返回类型函数
- 当使用比格式支持的精度更高的精度来显示数字时,会写出什么数据
- 如何计算具有指定类型的表达式的相对精度和绝对精度
- 如何打印boost多精度128位无符号整数
- 检查是否以特定精度给出双精度
- 转换函数,将 std::数组的双精度作为参数或双精度作为参数单独转换
- C 字符串返回字符串的整数/双精度/长整型值
- 为什么将双精度转换为 int 似乎在第 16 位数字之后将其四舍五入?
- 如何使双精度值的 C++ 和 C# 中的结果相同
- 使用浮点数和双精度数的非常小数字的数学
- 使用 Xcode 将双精度存储在数组C++中
- 为什么输出精度没有正确舍入?
- 在 C++ 中将双精度变量写入二进制文件
- 如何从字符串转换为双精度*