首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >读取字符串中的浮点值,精度最高可达6

读取字符串中的浮点值,精度最高可达6
EN

Stack Overflow用户
提问于 2009-11-04 16:41:02
回答 2查看 951关注 0票数 0

我必须从字符串中读取FLOT值,精度可达6,当前代码仅读取前6位数字。提前感谢

代码语言:javascript
运行
复制
template <class T>
bool from_string(T& t,    const std::string& s, 
                 std::ios_base& (*f)(std::ios_base&))
{
  std::istringstream iss(s);
  return !(iss >> f >> t).fail();
}

int main()
{
  int i;
  float f;
 // the third parameter of from_string() should be 
  // one of std::hex, std::dec or std::oct
  if(from_string<int>(i, std::string("ff"), std::hex))
  {
    std::cout << i << std::endl;
  }
  else
  {
    std::cout << "from_string failed" << std::endl;
  }

  if(from_string<float>(f, std::string("1456.909"), std::dec))
  {
    std::cout << f << std::endl;
  }
  else
  {
    std::cout << "from_string failed" << std::endl;
  }
  return 0;
} 
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2009-11-04 18:24:46

我很确定它是在读所有的数字。问题似乎出在你所期望的地方。让我们说得更清楚一点:如果在float中读取1456.90900000000000000000000000000,您会期望发生什么

票数 2
EN

Stack Overflow用户

发布于 2009-11-05 01:53:56

如果你想做比6位更好的运算,你需要使用双精度,而不是浮点数。你的问题是"6位精度“,也是”前6位数“,但你提供的输入是7位数。

浮点数只能包含6位精度,即x.yzpqrs、xy.zpqrs或xyzpq.rs。如果你想保留6位小数,那么你需要使用double。

例如,您可以使用cout.precision(7)让它输出更多的小数位,在本例中,它将打印正确的答案,即使C实际上并没有存储7位数字,只是近似于正确的答案。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1672419

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档