Math.Round函数说明

经过测试发现Math.Round函数存在这个问题,采用的是“四舍六入五成双”的方式
     具体参考:http://blog.joycode.com/ghj/posts/9474.aspx
    譬如:Math.Round(1.5) = 2
          Math.Round(2.5) = 2
 
     而Sqlserver中采用的是传统的四舍五入的方式,为了保证前台程序与后台数据库的计算方法一致。
     所以在Public中增加了一个类和两个静态方法
     可以采用:MyMath.Round()方法来替代Math.Round()的方法

public static decimal Round(decimal number)
  {
      return EMSMath.Round(number,0) ;
  }

  public static decimal Round(decimal number, int dec)
  {
      string numStr = number.ToString() ;

      if(numStr == "0") return (decimal)0.0 ;

      int    decIndex = numStr.IndexOf(".",0) ;

      if(numStr.Length <= decIndex + dec + 1)
          return number ;

      string decStr = numStr.Substring(decIndex + dec + 1) ;

      decStr = decStr.Replace("0","") ;

     if(decStr == "5")
     {
          int lastNum ;

          if(dec == 0)
                lastNum = int.Parse(numStr.Substring(decIndex - 1,1)) ;
         else
               lastNum = int.Parse(numStr.Substring(decIndex + dec,1)) ;

         if( lastNum % 2 == 0)
          {
              decimal addNumer = (decimal)1.0;
              for(int i = 0; i < dec ; i ++)
             {
                 addNumer = addNumer * (decimal)0.1 ;
             }

             return Math.Round(number,dec) + addNumer ;
         }
         else
           return Math.Round(number,dec) ;
       }  
      else
         return Math.Round(number,dec) ;
  }

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值