国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

JavaScript 浮點數運算 精度問題

2024-05-06 14:13:41
字體:
來源:轉載
供稿:網友
Js代碼
代碼如下:
<script type="text/javascript" language="javascript">
alert(1/3);//彈出: 0.3333333333333333
alert(0.09999999 + 0.00000001);//彈出: 0.09999999999999999
alert(-0.09999999 - 0.00000001);//彈出: -0.09999999999999999
alert(0.012345 * 0.000001);//彈出: 1.2344999999999999e-8
alert(0.000001 / 0.0001);//彈出: 0.009999999999999998
</script>
<script type="text/javascript" language="javascript">
    alert(1/3);//彈出: 0.3333333333333333
    alert(0.09999999 + 0.00000001);//彈出: 0.09999999999999999
    alert(-0.09999999 - 0.00000001);//彈出: -0.09999999999999999
    alert(0.012345 * 0.000001);//彈出: 1.2344999999999999e-8
    alert(0.000001 / 0.0001);//彈出: 0.009999999999999998
</script>
[code]
按正常計算的話,除第一行外(因為其本身就不能除盡),其他都應該要得到精確的結果,從彈出的結果我們卻發現不是我們想要的正確結果。為了解決浮點數運算不準確的問題,在運算前我們把參加運算的數先升級(10的X的次方)到整數,等運算完后再降級(0.1的X的次方)。現收集并整理貼于此,以備后用。
加法
Js代碼
[code]
//說明:javascript的加法結果會有誤差,在兩個浮點數相加的時候會比較明顯。這個函數返回較為精確的加法結果。
//調用:accAdd(arg1,arg2)
//返回值:arg1加上arg2的精確結果
function accAdd(arg1,arg2){
var r1,r2,m;
try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0}
try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0}
m=Math.pow(10,Math.max(r1,r2))
return (arg1*m+arg2*m)/m
}
//給Number類型增加一個add方法,調用起來更加方便。
Number.prototype.add = function (arg){
return accAdd(arg,this);
}
//說明:javascript的加法結果會有誤差,在兩個浮點數相加的時候會比較明顯。這個函數返回較為精確的加法結果。
//調用:accAdd(arg1,arg2)
//返回值:arg1加上arg2的精確結果
function accAdd(arg1,arg2){
var r1,r2,m;
try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0}
try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0}
m=Math.pow(10,Math.max(r1,r2))
return (arg1*m+arg2*m)/m
}
//給Number類型增加一個add方法,調用起來更加方便。
Number.prototype.add = function (arg){
return accAdd(arg,this);
}
減法
Js代碼
[code]
//說明:javascript的減法結果會有誤差,在兩個浮點數相加的時候會比較明顯。這個函數返回較為精確的減法結果。
//調用:accSub(arg1,arg2)
//返回值:arg1減上arg2的精確結果
function accSub(arg1,arg2){
return accAdd(arg1,-arg2);
}
//給Number類型增加一個sub方法,調用起來更加方便。
Number.prototype.sub = function (arg){
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 淮北市| 霍林郭勒市| 佛教| 仁寿县| 洪洞县| 天长市| 城固县| 改则县| 湘阴县| 广灵县| 那曲县| 荣昌县| 江达县| 云南省| 长汀县| 洛隆县| 久治县| 绥阳县| 蕉岭县| 天峻县| 彭州市| 肇庆市| 甘谷县| 新平| 马公市| 九寨沟县| 安泽县| 江华| 和平县| 名山县| 德钦县| 河源市| 九龙坡区| 水城县| 武邑县| 宁波市| 夏邑县| 延安市| 盘山县| 思南县| 东城区|