讀書筆記之(測試驅(qū)動開發(fā)實用指南)(待續(xù))

             一直都對TDD很感興趣,也很向往Test Driven 的開發(fā)方式,雖然在網(wǎng)絡(luò)上看過大大小小的很多文章,
          但感覺還是不是很深刻,希望通過這本書,能讓我在對TDD的認(rèn)識上更上一層樓.也希望能在今后的在工作中應(yīng)用它.
          同時,記錄一下閱讀該書時的一些總結(jié)及想法.也希望能和大家交流.
          一.概述:
             該書主要講了四部分.
             (1)  介紹了TDD相關(guān)背景知識(TDD、Refactoring、Programing by Intention)
             (2)  介紹了相關(guān)工具與技術(shù)(Junit、Mock)
             (3)  詳細(xì)介紹了一個采用TDD開發(fā)的GUI項目
             (4)  闡述了xUnit相關(guān)框架

          二. 總結(jié)

            任何一本XP或TDD的書上都會提到這些概念,這里就個人的理解總結(jié)一下
             1. 為什么要TDD?
             任何人從程序員到用戶,都明白測試有益,但為什么發(fā)布的軟件總是存在bug,讓我們先來看看傳統(tǒng)測試方法帶來的弊端:
               a.測試常常時在code完后編寫,或者某些(P)programer一完成編碼,就轉(zhuǎn)而繼續(xù)從事其他項目開發(fā).當(dāng)P不在與某個程序同呼吸、共命運時,也許再處理其中的問題是要花更多的時間和精力的.

               b.測試不是由編寫代碼的人完成,因此,再他們沒有充分理解代碼時,是很難編寫出充分的測試的.

               c.測試是依照文檔編寫的,文檔和代碼同步嗎
          ?

               d.如果測試不能否自動進(jìn)行,那它們能被頻繁的、經(jīng)常的運行嗎?

               e.不充分的測試導(dǎo)致的致命問題就是當(dāng)你修復(fù)了一處bug,卻不知道帶來的潛在的更大bug.

          2. 什么是TDD?
               a.首先編寫測試
                   當(dāng)有一項任務(wù)要做時候,先編寫出用于測試功能是否符合要求的代碼,然后在編寫足夠讓測試通過的代碼,
                  接著再編測試、再編代碼......
               
               b.除非存在相關(guān)測試,否則不寫任何產(chǎn)品代碼
                    極限編程的原則就是在相關(guān)測試沒有編寫之前,不編寫任何功能代碼.因為系統(tǒng)中的一切必須是可測的.所有的測試代碼
                   都是你執(zhí)行重構(gòu)和集成的先決條件,如果在沒有測試的環(huán)境中,你無意修改了部分代碼,你能夠自信的進(jìn)行重構(gòu),集成?

               c.由測試來決定需要編寫怎樣的代碼
                     只編寫讓最新的測試通過的代碼,簡單的說,就是"編寫最簡單但又能工作的代碼(do the simpleest thing               that could posibilly work)        

               d.維護一套詳盡的測試集.
                   保證你重構(gòu)和集成的充分條件.同時,你應(yīng)該用事實、用數(shù)據(jù)來證明你的代碼是正確的.


           
          關(guān)于重構(gòu),Martin Fowler 的<Rafactoring>是真正的權(quán)威.這里就不具體說了.
          3
          .什么是重構(gòu)?
               在不改變外部行為的條件下,對現(xiàn)有代碼進(jìn)行修改的過程.
          4.何時重構(gòu)?
               重構(gòu)應(yīng)在任何需要的時候,重復(fù)代碼、代碼意圖不清晰、bad smell.....


          5. 意圖導(dǎo)向的編程
               XP的核心理念之一,在編寫代碼的時候應(yīng)該清晰地表明自己地意圖.
               遲早會有人閱讀我們的代碼的,任何閱讀代碼的人,包括我們自己,都會在那種拙劣、復(fù)雜或含糊不清的情況下產(chǎn)生誤解.
               如何編寫意圖清晰明確的代碼完全值得任何程序員去學(xué)習(xí).....
              a. 名字
                 (1) 用名詞或名詞短語作為類的名字
                       如MovieRating,MoveListReader等

                 (2) 使用形容詞、一般名詞或名詞短語為接口命名.
                       優(yōu)先使用形容詞來命名接口,通常以-able,-Aware等結(jié)尾,如Runnable,Serializable,以及spring中的xxxAware
                 
                 (3) 動詞或動詞短語做方法名
                
                 (4) 名詞或名詞短語作為變量名.

          三 牢騷
              這部分純屬于個人的扯談,不過有想法就留念一下吧....呵呵
             無論是TDD,還是重構(gòu),出發(fā)點真的太好了,可能是這些牛人在總結(jié)了多少次彎路后的經(jīng)驗之談.但從目前的情況看,我感覺需要一套完整的測試集很重要,但也正因為如此,現(xiàn)在的測試手段、測試框架越來越多,程序員需要掌握的不僅僅是新技術(shù),好工具,在對測試的理解、重要性以及測試工具的使用上又要花大力氣了.
             其實個人比較向往TDD,覺得它應(yīng)該完全改善了你編程的思維,讓你真正從需求的角度出發(fā),讓你的代碼具有可測性,但這可能只是偶的目標(biāo)了.
          目前,偶的要求不高,覺得能在測試集合完整的情況下,編碼、重構(gòu)就算是一種享受了.
          目前所在的公司,真的很讓人郁悶,大家連測試都不怎么作,還整天鼓吹著Refactoring,上次給Manager寫了一封建議信后,還和我講了很多大道理,不過還算有點效果,雖然case較少,但至少現(xiàn)在開始測試了.
             什么時候偶的代碼能成為一件精雕細(xì)酌的藝術(shù)品,我能成為這個藝術(shù)品的藝術(shù)家呢?估計只有在dream中了....
             唉,中國的軟件,提不成!

          posted on 2007-06-19 21:16 想飛就飛 閱讀(674) 評論(1)  編輯  收藏 所屬分類: 讀書筆記

          評論

          # re: 讀書筆記之()(待續(xù)) 2007-06-19 21:25 阿南

          哥們兒,中國軟件什么都提不成,沒人愿意花錢,讓你跟他一起玩!  回復(fù)  更多評論   

          公告


          導(dǎo)航

          <2007年6月>
          272829303112
          3456789
          10111213141516
          17181920212223
          24252627282930
          1234567

          統(tǒng)計

          常用鏈接

          留言簿(13)

          我參與的團隊

          隨筆分類(69)

          隨筆檔案(68)

          最新隨筆

          搜索

          積分與排名

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 涟水县| 临江市| 垦利县| 丰台区| 克山县| 岳阳市| 容城县| 方城县| 唐山市| 彭山县| 岳普湖县| 蒙阴县| 秦皇岛市| 宜宾市| 洛南县| 无极县| 绥芬河市| 绥中县| 通榆县| 镇江市| 北辰区| 兴化市| 图木舒克市| 崇文区| 陆良县| 阳东县| 崇义县| 孝义市| 梁山县| 岳西县| 三江| 溆浦县| 观塘区| 洞头县| 井研县| 秀山| 图们市| 德兴市| 安福县| 武穴市| 岑溪市|