将字符串转换为长双精度时,我在 QNX 中失去了精度。你知道如何解决这个问题吗?
我正在使用 C++。我试过双倍和浮动,没有问题。
#include <iostream>
#include <string>
#include <limits>
#include <sstream>
int main(){
long double originalNumber = std::numeric_limits<long double>::max() / 2;
long double convertedNumber;
// From long double to string
std::ostringstream ostr;
ostr << originalNumber;
std::string tmp_str = ostr.str();
//From string to long double
std::istringstream istr(tmp_str);
istr >> convertedNumber;
// Check if they are similar
if (originalNumber == convertedNumber)
std::cout<< "The same\n";
else
std::cout<< "Not the same\n";
return 0;
}
结果总是Not the same