<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    新的起點(diǎn) 新的開始

    快樂生活 !

    銀行在線轉(zhuǎn)賬系統(tǒng)中竟然有這樣的Bug 而長達(dá)4年沒有人發(fā)現(xiàn),看看大家能不能找出問題?一天過去了 沒有正解,今天說說正確答案

           最近忙于Fix Bug, 在某系統(tǒng)中發(fā)現(xiàn)一個(gè)Bug,而這個(gè)Bug竟然從2004年就存在!! 有這么一個(gè)Scenerio:
     周期性轉(zhuǎn)賬,計(jì)算需要轉(zhuǎn)賬次數(shù) eg: 200 每次20 那么 轉(zhuǎn)賬次數(shù)=10    239 每次轉(zhuǎn) 23.9 
    轉(zhuǎn)賬次數(shù)=10

    代碼1:

    float  sumTranferAmount;
    float  perTransferAmount;
    transactionCount = (int)Math.ceil((Math.round((sumTRanferAmount/perTransferAmount)*100.0/ 100.0))

    代碼2:

            float sumTranferAmount;
            
    float perTransferAmount;
            
    int transactionCount = (int)(sumTranferAmount / perTransferAmount);
            
    if ( (sumTranferAmount%  (perTransferAmount!= 0){
                transactionCount
    ++;
     
            }

    這兩段代碼那個(gè)正確呢? 大家不要測(cè)試,看能不能找出問題?

    其實(shí)這兩個(gè)代碼都是錯(cuò)誤的。
    代碼1不要說,錯(cuò)到十萬八千里了。對(duì)于代碼2,其實(shí)在取余運(yùn)算出現(xiàn)了問題。取余運(yùn)算前提是這兩個(gè)數(shù)不是小數(shù)(金額都是保留兩位小數(shù))。
    只要讓sumTranferAmount
    *100%pertransferAmount*100 就正確了。

    posted on 2009-04-10 15:01 advincenting 閱讀(2857) 評(píng)論(5)  編輯  收藏

    評(píng)論

    # re: 一個(gè)在線交易系統(tǒng)中竟然有這樣的Bug 而長達(dá)4年沒有人發(fā)現(xiàn),看看大家能不能不測(cè)試找出問題? 2009-04-10 16:11 lveyo

    JAVA里好像處理金額的計(jì)算最好不要用float,double這樣的簡單數(shù)據(jù)類型  回復(fù)  更多評(píng)論   

    # re: 一個(gè)在線交易系統(tǒng)中竟然有這樣的Bug 而長達(dá)4年沒有人發(fā)現(xiàn),看看大家能不能不測(cè)試找出問題? 2009-04-10 16:13 advincenting

    其實(shí)這兩個(gè)都不對(duì) 呵呵!  回復(fù)  更多評(píng)論   

    # re: 銀行在線轉(zhuǎn)賬系統(tǒng)中竟然有這樣的Bug 而長達(dá)4年沒有人發(fā)現(xiàn),看看大家能不能找出問題? 2009-04-10 23:30 MyYate

    呵呵,第一個(gè)肯定是錯(cuò)的,我看了一下,如果有239元,我每次轉(zhuǎn)238元,應(yīng)該需要轉(zhuǎn)兩次。
    第二個(gè)不清楚,不過如果我不考慮實(shí)際情況,每次轉(zhuǎn)238.999999元,transactionCount =1,所以也是錯(cuò)的。
    float,double計(jì)算就是這點(diǎn)不好。  回復(fù)  更多評(píng)論   

    # re: 銀行在線轉(zhuǎn)賬系統(tǒng)中竟然有這樣的Bug 而長達(dá)4年沒有人發(fā)現(xiàn),看看大家能不能找出問題? 2009-04-12 11:01 程吉

    不是有可以解決不能精確計(jì)算的float和double類型的類么???
    不能用?  回復(fù)  更多評(píng)論   

    # re: 銀行在線轉(zhuǎn)賬系統(tǒng)中竟然有這樣的Bug 而長達(dá)4年沒有人發(fā)現(xiàn),看看大家能不能找出問題?一天過去了 沒有正解,今天說說正確答案 2009-04-15 12:12 origo

    建議采用BigDecimal,或者用Double。在Float之間的除運(yùn)算會(huì)出現(xiàn)差錯(cuò),貌似會(huì)在.000級(jí)別出現(xiàn)誤差。  回復(fù)  更多評(píng)論   


    只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


    網(wǎng)站導(dǎo)航:
     

    公告

    Locations of visitors to this pageBlogJava
  • 首頁
  • 新隨筆
  • 聯(lián)系
  • 聚合
  • 管理
  • <2009年4月>
    2930311234
    567891011
    12131415161718
    19202122232425
    262728293012
    3456789

    統(tǒng)計(jì)

    常用鏈接

    留言簿(13)

    隨筆分類(71)

    隨筆檔案(179)

    文章檔案(13)

    新聞分類

    IT人的英語學(xué)習(xí)網(wǎng)站

    JAVA站點(diǎn)

    優(yōu)秀個(gè)人博客鏈接

    官網(wǎng)學(xué)習(xí)站點(diǎn)

    生活工作站點(diǎn)

    最新隨筆

    搜索

    積分與排名

    最新評(píng)論

    閱讀排行榜

    評(píng)論排行榜

    主站蜘蛛池模板: 污视频在线观看免费| 免费看国产成年无码AV片 | 亚洲欧洲精品一区二区三区| **一级毛片免费完整视| 亚洲AV无码男人的天堂| 久久综合日韩亚洲精品色| 成人性生交大片免费看无遮挡| 人禽伦免费交视频播放| 亚洲最大免费视频网| 免费真实播放国产乱子伦| 久久99精品免费视频| 亚洲精品GV天堂无码男同| 亚洲精品白浆高清久久久久久| 日韩av无码成人无码免费| 久久久久久噜噜精品免费直播 | 在线人成免费视频69国产 | 91免费播放人人爽人人快乐| 免费一级毛片在线播放视频免费观看永久 | 亚洲日韩精品无码专区加勒比☆| 不卡精品国产_亚洲人成在线| 亚洲免费在线视频播放| 免费看一级一级人妻片| 亚洲a∨无码男人的天堂| 不卡一卡二卡三亚洲| 日韩毛片免费在线观看| 无码少妇精品一区二区免费动态| 国产亚洲人成在线影院| 亚洲国产福利精品一区二区| 亚洲精品国产精品乱码不99| 国产男女性潮高清免费网站| 亚洲免费在线视频播放| 国产成人精品免费久久久久| 久青草国产免费观看| 亚洲精品无码久久久久牙蜜区| 久久久久亚洲av无码专区喷水| 中文亚洲AV片在线观看不卡| 免费涩涩在线视频网| 国产在线观看麻豆91精品免费| 国产拍拍拍无码视频免费| 成人在线免费视频| 久久精品国产亚洲av品善|