科学记数法中的字符串C++以双重转换

miy*_*iya 14 c++ math scientific-notation type-conversion

我有一个数据库填充了以下双打:

1.60000000000000000000000000000000000e+01
Run Code Online (Sandbox Code Playgroud)

有人知道如何在C++中将这样的数字转换为double吗?

是否有"标准"方式来做这类事情?或者我必须自己动手?

现在我正在做这样的事情:

#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;
}
Run Code Online (Sandbox Code Playgroud)

谢谢!

Tho*_*mas 18

像这样的东西?这将是"C++"的做法......

#include <sstream>
using namespace std;

// ...

    string s = "1.60000000000000000000000000000000000e+01";
    istringstream os(s);
    double d;
    os >> d;
    cout << d << endl;
Run Code Online (Sandbox Code Playgroud)

打印16.

  • 如果你有提升,那么`double d = boost :: lexical_cast <double>(s)`会做同样的事情. (6认同)

Rus*_*ist 11

你想要标准的c函数atof([A] SCII到[F] loat,但它实际上使用的是双精度而不是浮点数).

  • @sbi:`strtod`就像`atof`一样工作,除了它允许你明确地检测错误. (4认同)
  • @Heath:当你跳过重要的步骤时,很快就会很快:`atof("0.0")`vs`atof("blah")`.(注意:我不是想要保护C++流,它们比它们应该慢得多.但它们确实以明确的方式指出了错误.) (2认同)