QT中QString转Double和Float的问题

zhujun1980 2019-07-12 08:00:53
在QT中遇到奇怪的问题:
QString x = "814.536";
double d = x.toDouble();
floar f = x.toFloat();

最终结果
d = 814.53599999999994
f = 814.536011

结果是debug时看到的值。有人能解释下吗?
...全文
4512 2 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
轻箬笠 2019-07-13
  • 打赏
  • 举报
回复
double和float数存在精度问题。具体数值参照IEEE754标准
豆丷 2019-07-13
  • 打赏
  • 举报
回复
数值在计算机里都是二进制的,所以二进制转十进制小数的时候会出现误差, 至于长度,float和double的精度不同,也就是小数点后保留的位数不同, 所以进行条件判断的时候double和float类型的值不要用“==” (我用的是绝对值判断 fabs(a-b)<1e-5)

65,186

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧