欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

程序中兩個(gè)Double類型相加出現(xiàn)誤差的解決辦法

 更新時(shí)間:2013年04月26日 15:44:04   作者:  
本篇文章介紹了,程序中兩個(gè)Double類型相加出現(xiàn)誤差的解決辦法。需要的朋友參考下

今天在自己做的系統(tǒng)中,發(fā)現(xiàn)了一個(gè)奇怪的現(xiàn)象:幾個(gè)Double類型的數(shù)據(jù)相加,到最后得出的金額比正確數(shù)值總是少了幾毛錢(qián)。以為是程序里的計(jì)算方法有問(wèn)題,可是排查了很多地方,始終沒(méi)有找到問(wèn)題出在哪里。最后干脆把計(jì)算方法一句一句拆分,得到了最后最簡(jiǎn)單的一步,就是把兩個(gè)具體的數(shù)值相加,但是最后的結(jié)果居然還是錯(cuò)誤的。比如,現(xiàn)在已經(jīng)到了最簡(jiǎn)單的一步:

復(fù)制代碼 代碼如下:

double n = 171.6;
double m = 28.17;
double k = n + m;

  按理說(shuō)k的值應(yīng)該是199.77,但其實(shí)得到的居然是199.76999999999998。

     我們的系統(tǒng)里有保留小數(shù)位數(shù)為4位,按理是可以四舍五入成199.77的。但是因?yàn)橛凶鼋痤~的合計(jì),是幾十甚至幾百個(gè)數(shù)據(jù)的相加,由于每?jī)蓚€(gè)數(shù)相加的時(shí)候都可能產(chǎn)生上述誤差,因此最后得到的結(jié)果已經(jīng)有了近0.7的誤差,就算再四舍五入也于事無(wú)補(bǔ)了。

     上網(wǎng)查了一下相關(guān)資料,覺(jué)得CSDN論壇里的這個(gè)帖子的解釋還是比較詳細(xì)的:http://bbs.csdn.net/topics/300023952,大意是說(shuō)由于運(yùn)算的時(shí)候進(jìn)行了進(jìn)制的轉(zhuǎn)換造成的(見(jiàn)8樓回復(fù)),所有的精度類型在幾乎所有語(yǔ)言下都有這個(gè)問(wèn)題。比較有效的解決辦法是使用BigDecimal(見(jiàn)14樓回復(fù)),但是我個(gè)人認(rèn)為那個(gè)BigDecimal的解決辦法太麻煩了,至少對(duì)于我的系統(tǒng)來(lái)說(shuō)是這樣。還不如每加一次之后都進(jìn)行一次字符串轉(zhuǎn)換,保留有效的小數(shù)位數(shù),比如,上述語(yǔ)句可以改寫(xiě)成:

復(fù)制代碼 代碼如下:

double n = 171.6;
double m = 28.17;
//double k = n + m;
String kn = (n + m).ToString("N4");    //保留4位小數(shù)
double k = Convert.ToDouble(kn);

  也就是說(shuō),在String kn這一步,就已經(jīng)把誤差調(diào)整好了,得到的k值就是正確的了。這樣每次相加都處理一下誤差,無(wú)論要算多少個(gè)數(shù)據(jù)的合計(jì)也不用擔(dān)心會(huì)出現(xiàn)誤差過(guò)大的情況了。

    當(dāng)然最好是把這種處理方法做成一個(gè)公用方法,專門(mén)用來(lái)處理兩個(gè)數(shù)的相加。

相關(guān)文章

最新評(píng)論