• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            stevenyao

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              22 隨筆 :: 1 文章 :: 67 評論 :: 0 Trackbacks
            最近剛修復了一個存在長達3年多的bug,是這樣的

            軟件從3.0 升級到3.1的時候,某個數據結構不再兼容了,但是一個數據處理的代碼需要兼容以前3.0的數據結構。
            于是當時的開發人員寫下了這么一段代碼,偽代碼如下:

            if isVersion(3.1) then
                   process Data in 3.1 format
            else
                   process Data in 3.0 format
            endif

            這樣的代碼,當時工作很好,測試絕對沒有問題,但是當軟件版本繼續升級到3.2....4.0....5.0....
            問題就出來了,當時的判斷是is 判斷,而不是比較大小,所以3.2以及以后版本都會當作3.0處理,碰巧的是 Process data是另外開發組開發的,他們提供了一定的容錯性,可以識別3.0版本的數據格式并處理,但是這樣會損失一點性能,大約20%左右,但是當初數據量都不大所以測試中也沒人發現。直到了5.1版本,這時候數據量變得很大了,這點性能損失變得比較明顯了,因為這系統里數據處理涉及很多加密解碼壓縮校驗以及遠程調用等等。。。3年來浪費了如此多資源都來源于當初那個開發人員的一念之差,如果他寫成 if versionGreatThan(3.0) 就一切OK。

            我了解了一下歷史,那時候正是開發很緊張的時候,進度壓力很大,這個編碼估計也是臨時打的補丁,沒有深思熟慮。
            現實中我們不可避免地要使用些暴力手段寫點 hardcode來打補丁,有時候進度壓力很大,沒辦法的,但是我覺得應該有養成良好的習慣,在做這樣的事情的時候盡量縮小影響的范圍,比如可以寫成這樣:

            if isVersion(3.1) then
                   process Data in 3.1 format
            else if isVersion(3.0)
                   process Data in 3.0 format
            else
                   ASSERT(FALSE)
            endif

            這樣的話,當系統升級到3.2的時候這個ASSERT會跳出來,提醒你這里有問題,那時候如果時間寬裕可以去找出更優雅的解決方案。
            posted on 2010-03-13 13:25 姚冬 閱讀(542) 評論(0)  編輯 收藏 引用
            久久精品水蜜桃av综合天堂| 久久99国产综合精品免费| 99久久国产免费福利| 久久国产精品一区| 精品久久久久中文字| 香蕉久久av一区二区三区| 99久久国产综合精品五月天喷水| 国产精品免费看久久久香蕉| 精品国产VA久久久久久久冰| 国产AV影片久久久久久| 久久久久av无码免费网| 国内精品伊人久久久久网站| 午夜不卡久久精品无码免费| 精品无码久久久久久久动漫| 97精品久久天干天天天按摩| 国产成人久久精品一区二区三区| 久久久久国产一级毛片高清板| 一本一本久久aa综合精品| 久久成人18免费网站| av国内精品久久久久影院| 久久久久久久91精品免费观看| 天天综合久久久网| 国产精品综合久久第一页 | 91视频国产91久久久| 四虎影视久久久免费| 久久久国产精品| 精品久久久久久国产三级| 精品熟女少妇a∨免费久久| 亚洲欧美伊人久久综合一区二区 | 日韩av无码久久精品免费| 久久久久久国产精品美女| 久久九九久精品国产| 精品多毛少妇人妻AV免费久久| .精品久久久麻豆国产精品| 久久天堂AV综合合色蜜桃网| 99久久国产宗和精品1上映 | 久久久久久精品无码人妻| 欧美日韩精品久久久免费观看| 久久男人AV资源网站| 一本久道久久综合狠狠躁AV| 伊人热热久久原色播放www|