【发布时间】:2010-12-15 04:34:48
【问题描述】:
我有一个数据库,里面装满了像下面这样的双精度数:
1.60000000000000000000000000000000000e+01
有人知道如何在 C++ 中将这样的数字转换为双精度数吗?
有没有一种“标准”的方式来做这类事情?还是我必须推出自己的功能?
现在我正在做这样的事情:
#include <string>
#include <sstream>
int main() {
std::string s("1.60000000000000000000000000000000000e+01");
std::istringstream iss(s);
double d;
iss >> d;
d += 10.303030;
std::cout << d << std::endl;
}
谢谢!
【问题讨论】:
-
什么类型的数据库?该字段周围的数据库架构是什么?
-
您需要保持这个数字的精度是多少?如果保持高精度不是问题,您可以简单地“剪切”此字符串并使用普通 C 函数将其转换为双精度。
-
请注意,您应该在读取字符串流后检查它的状态。阅读可能会失败。
-
不是重复的,这是相反的操作。
标签: c++ math type-conversion scientific-notation