zoukankan      html  css  js  c++  java
  • javarscript的加法、乘法、除法不准确的问题

      已除法为例:如果你需要计算0.3除以0.1的结果,你可以想都不需要想,直接报出等于3的结果。可是伟大的js偏偏不会算这个简单的除法。它得出的结果是:2.9999999999999........。  

      这是js得通病,在涉及到多个浮点数时,很多时候它没法计算的准确,我们只能通过其他方法来得到我们所需要的结果。  

      除法我们可以通过这个js获得我们需要的准确的结果:

      //除法

        function division(num1,num2){

            var t1=0,t2=0,r1,r2;

            try{t1=num1.toString().split(".")[1].length}catch(e){}

            try{t2=num2.toString().split(".")[1].length}catch(e){}

            with(Math){

                 r1=Number(num1.toString().replace(".",""))  

                r2=Number(num2.toString().replace(".",""))  

                return (r1/r2)*pow(10,t2-t1);  

            }  

      }

      乘法我们可以通过这个js获得我们需要的准确的结果:

       //乘法 

      function multiplication(num1,num2) 

      { 

            var m=0,s1=num1.toString(),s2=num2.toString();

             try{m+=s1.split(".")[1].length}catch(e){} 

            try{m+=s2.split(".")[1].length}catch(e){} 

            return Number(s1.replace(".",""))*Number(s2.replace(".",""))/Math.pow(10,m) 

        } 

     

      加法我们可以通过这个js获得我们需要的准确的结果: 

       //加法 

        function addition(num1,num2){ 

            var r1,r2,m; 

            try{r1=num1.toString().split(".")[1].length}catch(e){r1=0} 

            try{r2=num2.toString().split(".")[1].length}catch(e){r2=0} 

            m=Math.pow(10,Math.max(r1,r2));

             return (num1*m+num2*m)/m; 

        }

     

  • 相关阅读:
    linux安装及入门
    20165103学习基础和C语言基础调查
    20165103 我期望的师生关系
    自旋锁,偏向锁,轻量级锁 和 重量级锁
    volatile的使用及其原理
    (PASS)什么是原子性和原子性操作?
    Linux操作系统 和 Windows操作系统 的区别
    Linux常用命令大全(很全面)
    CAS机制总结
    CAS -- ABA问题的解决方案
  • 原文地址:https://www.cnblogs.com/xujie/p/1772247.html
Copyright © 2011-2022 走看看