• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C#教程 > 程序中两个Double类型相加出现误差的解决办法

程序中两个Double类型相加出现误差的解决办法

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了double 误差,double类型,double类型范围,c语言double类型,matlab double类型等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

今天在自己做的系统中,发现了一个奇怪的现象:几个Double类型的数据相加,到最后得出的金额比正确数值总是少了几毛钱。以为是程序里的计算方法有问题,可是排查了很多地方,始终没有找到问题出在哪里。最后干脆把计算方法一句一句拆分,得到了最后最简单的一步,就是把两个具体的数值相加,但是最后的结果居然还是错误的。比如,现在已经到了最简单的一步:

     我们的系统里有保留小数位数为4位,按理是可以四舍五入成199.77的。但是因为有做金额的合计,是几十甚至几百个数据的相加,由于每两个数相加的时候都可能产生上述误差,因此最后得到的结果已经有了近0.7的误差,就算再四舍五入也于事无补了。

     上网查了一下相关资料,觉得CSDN论坛里的这个帖子的解释还是比较详细的:http://bbs.csdn.net/topics/300023952,大意是说由于运算的时候进行了进制的转换造成的(见8楼回复),所有的精度类型在几乎所有语言下都有这个问题。比较有效的解决办法是使用BigDecimal(见14楼回复),但是我个人认为那个BigDecimal的解决办法太麻烦了,至少对于我的系统来说是这样。还不如每加一次之后都进行一次字符串转换,保留有效的小数位数,比如,上述语句可以改写成:

    当然最好是把这种处理方法做成一个公用方法,专门用来处理两个数的相加。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 程序中两个Double类型相加出现误差的解决办法

相关文章

  • 2017-05-28基于C#的UDP协议的同步通信实现代码
  • 2017-05-28在多线程中调用winform窗体控件的实现方法
  • 2017-05-28C#条码生成及打印实例代码
  • 2017-05-28C#中实现Fluent Interface的三种方法
  • 2017-05-28C#中winform实现自动触发鼠标、键盘事件的方法
  • 2017-05-28C#实现关闭子窗口而不释放子窗口对象的方法
  • 2017-05-28自动输出类的字段值实用代码分享
  • 2017-05-28C#简单的通用基础字典实现方法
  • 2017-05-28C#获取路径的几种方式实例分析
  • 2017-05-28带着问题读CLR via C#(笔记二)类型基础

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • c# 文件(夹)创建与删除
    • WPF的ListView控件自定义布局用法实例
    • 探讨如何用委托处理排序
    • C#数组的常用操作方法小结
    • C#简单实现显示中文格式星期几的方法
    • C#利用win32 Api 修改本地系统时间、获取硬盘序列号
    • c#给图片添加文字的代码小结
    • C# TreeView无限目录树实现方法
    • 深入多线程之:Wait与Pulse的使用详解
    • c#实现几种数据库的大数据批量插入

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有