在线现看午夜福利片|女人16久久免费视频|鲁丝片一区鲁丝片二区鲁丝|一区二区三区欧美在线

  1. 
    
    <b id="glvx9"></b>
        1. <blockquote id="glvx9"><meter id="glvx9"></meter></blockquote>
            查看全部128種考試
            軟件水平考試
             考試動(dòng)態(tài) 報(bào)考指南 歷年真題 模擬試題 復(fù)習(xí)資料 心得技巧 專(zhuān)業(yè)英語(yǔ) 技術(shù)文章 軟考論壇 考試用書(shū)
             程序員 軟件設(shè)計(jì)師 網(wǎng)絡(luò)管理員 網(wǎng)絡(luò)工程師 系統(tǒng)分析師 數(shù)據(jù)庫(kù)系統(tǒng)工程師
            1
            2
            3
            4
            5
            6
            7
            8
            9
            10
            yanruijie  
            【字體: 從企業(yè)的運(yùn)行價(jià)值鏈說(shuō)起——我眼中的測(cè)試驅(qū)動(dòng)開(kāi)發(fā)(TDD)
            從企業(yè)的運(yùn)行價(jià)值鏈說(shuō)起——我眼中的測(cè)試驅(qū)動(dòng)開(kāi)發(fā)(TDD)
            spks.exam8.com 來(lái)源:考試吧(Exam8.com) 更新:2007-1-25 18:11:29 軟件水平考試 考試論壇

              接下來(lái)抽象出SearchEngine的接口ISearchEngine,并讓SearchEngine實(shí)現(xiàn)該接口。其中接口方法包括ExactSearch和BlurSearch方法。將前面的測(cè)試代碼作小小的修改,修改后同樣需要在NUnit中運(yùn)行,保證順利通過(guò):
              [Test]
                public void TestSearching()
                  {
                      ISearchEngine engine = new SearchEngine();
                      Assert.IsNotNull(engine);
             
                      ……
                   }

              考察SearchResult類(lèi)型,該類(lèi)型的對(duì)象應(yīng)該在整個(gè)程序中只保留一個(gè)對(duì)象,因此,應(yīng)對(duì)此采用單例模式。修改測(cè)試代碼:
              [Test]
                public void TestSearching()
                  {
                     ISearchEngine engine = SearchEngine.Instante;
                      Assert.IsNotNull(engine);
             
                      ……
                   }
              根據(jù)測(cè)試代碼修改程序代碼,將SearchResult類(lèi)型的構(gòu)造函數(shù)改為private,并提供只讀的靜態(tài)屬性Instante,以此來(lái)獲得單例對(duì)象。

              僅僅是這樣還不夠的?紤]到搜索的范圍有多種情況,如internet,local machine,DB等。SearchEngine類(lèi)型應(yīng)該具體化不同類(lèi)型,并同時(shí)實(shí)現(xiàn)ISearchEngine接口。例如搜索范圍在internet,測(cè)試代碼如下:
              [Test]
                public void TestInternetSearching()
                  {
                      ISearchEngine engine = InternetSearchEngine.Instante;
                      Assert.IsNotNull(engine);
             
                      ……
                  }

              既然有如此多的類(lèi)型,類(lèi)型的創(chuàng)建就必須通過(guò)工廠(chǎng)進(jìn)行管理。此時(shí)測(cè)試代碼需要做進(jìn)一步的修改:
              [Test]
                public void TestInternetSearching()
                  {
                      ISearchEngineFacotry fatory = new         InternetSearchEngineFactory();
                      ISearchEngine engine = factory.CreateInstante(“Internet”);
                      Assert.IsNotNull(engine);
             
                      ……
                   }

              同理,我們應(yīng)該分別實(shí)現(xiàn)測(cè)試方法TestLocalSearching()和TestDBSearching()。

              按照這樣的思路,分別對(duì)存儲(chǔ)功能和顯示功能進(jìn)行重構(gòu)。記住,每做一步重構(gòu),都需要嚴(yán)格按照TDD的方式。首先寫(xiě)出測(cè)試代碼,然后在NUnit運(yùn)行。如果是紅燈,需要寫(xiě)出相應(yīng)的代碼,再運(yùn)行NUnit,直到全部均為綠燈為止。

            三、第一步的小結(jié)

              表面上看,這樣繁復(fù)地寫(xiě)測(cè)試代碼,程序代碼,確實(shí)是有些Kill Time了。但我們需要認(rèn)真地思考所謂“發(fā)現(xiàn)價(jià)值”的意義。通過(guò)測(cè)試先行的方式,以模擬客戶(hù)應(yīng)用的狀態(tài)來(lái)考量客戶(hù)的需求,并通過(guò)此驅(qū)動(dòng)程序員一步一步地到達(dá)“生產(chǎn)價(jià)值”的終點(diǎn)!鞍l(fā)現(xiàn)”與“生產(chǎn)”并行不悖,同時(shí)“質(zhì)檢員”一直跟隨其間,保證了產(chǎn)品的質(zhì)量。

              就好比Nike鞋的生產(chǎn),必須以體貼用戶(hù)的角度出發(fā),設(shè)計(jì)出吸引人的樣式,那么大規(guī)模的生產(chǎn)才會(huì)有盈利的可能。

              TDD的生產(chǎn)過(guò)程也許慢了一點(diǎn),但請(qǐng)不要忽略了它其實(shí)已經(jīng)省去了編碼后單元測(cè)試的時(shí)間。相加相減之后,又會(huì)浪費(fèi)多少時(shí)間呢?所以,千萬(wàn)不要以“時(shí)間緊”的理由來(lái)搪塞我哦。

              四、考察第三步——收獲價(jià)值

              傳統(tǒng)的方式,在產(chǎn)品生產(chǎn)出來(lái)之后,緊接著的是大量的測(cè)試,其中也包括單元測(cè)試;最后收獲了產(chǎn)品、一大堆源代碼和文檔。而TDD的方式,既省去了單元測(cè)試的過(guò)程,同時(shí)還收獲了另外一樣上帝賜予的禮物——測(cè)試類(lèi)或測(cè)試套件。

              測(cè)試類(lèi)絕對(duì)是一件奇妙的禮物。必須認(rèn)識(shí)到它的價(jià)值不只是在于“發(fā)現(xiàn)價(jià)值”的階段,它同樣是我們的“收獲”。

              第一:比代碼更好的文檔、比文檔更好的代碼
              有了它,不用鉆進(jìn)浩如煙海的文檔里,四顧茫然了。文檔的文字描述既不準(zhǔn)確,容易產(chǎn)生歧義,又容易產(chǎn)生文檔同步的問(wèn)題。也許它能促進(jìn)你對(duì)業(yè)務(wù)和架構(gòu)的理解,但對(duì)于程序本身,你無(wú)法從文檔中得到基本的啟示。

              那么看程序的源代碼嗎?你會(huì)在眾多的類(lèi)對(duì)象和方法中繞來(lái)繞去,最后一頭霧水,精疲力盡之后,還是一無(wú)所獲。

              而看測(cè)試代碼就不同了,你不需要了解每個(gè)方法的具體實(shí)現(xiàn),因?yàn)闇y(cè)試代碼是從客戶(hù)的應(yīng)用角度來(lái)書(shū)寫(xiě)的,看完測(cè)試代碼,你會(huì)很輕松地理清程序結(jié)構(gòu)的脈絡(luò)。

              第二:新兵訓(xùn)練營(yíng)的絕佳教材
              也許你的項(xiàng)目組新進(jìn)了員工,如果他熟悉TDD,那么,這些測(cè)試類(lèi)是他熟悉項(xiàng)目的最好文檔;如果他還沒(méi)聽(tīng)說(shuō)過(guò)TDD,不用著急,先把這些測(cè)試類(lèi)給他。只要他不是程序設(shè)計(jì)的新手,我想這個(gè)新兵會(huì)很快熟悉項(xiàng)目組開(kāi)發(fā)的方式。再讓他寫(xiě)幾個(gè)測(cè)試樣例,他會(huì)立即投入到TDD的懷抱中來(lái)的。

              第三:滿(mǎn)載而歸的信心
              項(xiàng)目開(kāi)發(fā)中,成員最寶貴的除了認(rèn)真、努力、團(tuán)隊(duì)精神之外,就是信心了。這里所謂的信心,并非是對(duì)自己能力充滿(mǎn)樂(lè)觀(guān)的估計(jì)和客觀(guān)地評(píng)價(jià)后,表現(xiàn)出來(lái)的精神面貌,而指的是程序員對(duì)代碼正確性的信心。無(wú)論這些代碼是自己寫(xiě)的,還是他人寫(xiě)的,只要嚴(yán)格按照TDD的要求進(jìn)行,你都會(huì)對(duì)它們充滿(mǎn)信心。雖然不能保證沒(méi)有bug,但必須承認(rèn)的是通過(guò)單元測(cè)試,我們已經(jīng)將bug降低到最小了。

            五、結(jié)論

              中國(guó)企業(yè)在企業(yè)運(yùn)行價(jià)值鏈上,走好了利潤(rùn)最低的第二步,卻忽略了“發(fā)現(xiàn)價(jià)值”和“收獲價(jià)值”對(duì)于一個(gè)企業(yè)的重要性。韓國(guó)三星在幾年之前還是一個(gè)虧損600多億美元的企業(yè),如今它已經(jīng)成功地扭虧為盈,并躋身世界五百?gòu)?qiáng)。原因很多,但不可忽視的是,他在價(jià)值鏈的首尾兩步中作得很好。從高端產(chǎn)品中發(fā)現(xiàn)價(jià)值,找到了目標(biāo)市場(chǎng);從品牌創(chuàng)造中收獲了價(jià)值,走向了世界。

              我不是說(shuō)軟件開(kāi)發(fā)一定要采用TDD的方式,它自然也有很多缺陷。然而,我們?cè)陂_(kāi)發(fā)的過(guò)程中,同樣要重視設(shè)計(jì)的“發(fā)現(xiàn)價(jià)值”階段,然后在收獲產(chǎn)品的同時(shí),不要忽略了還應(yīng)該收獲其他同樣值得珍視的“價(jià)值”。從這一點(diǎn)來(lái)看,也許TDD更符合這種價(jià)值鏈的模式。而我們程序員千萬(wàn)不要舍本逐末,過(guò)于偏執(zhí)地重視“生產(chǎn)價(jià)值”,以致于在軟件開(kāi)發(fā)方法上,總是落后于人,進(jìn)而受制于人!

              最后,謹(jǐn)以我之愚見(jiàn),思考TDD的方式,認(rèn)為T(mén)DD內(nèi)力精深,大約分為四種無(wú)上之力:
              1、驅(qū)動(dòng)力——驅(qū)動(dòng)程序代碼編寫(xiě);
              2、學(xué)習(xí)力——新兵訓(xùn)練營(yíng)之絕佳教材;
              3、自信力與他信力——bug降到最低;
              4、控制力——與重構(gòu)緊密接合,牢牢控制開(kāi)發(fā)過(guò)程。

            更多軟考資料請(qǐng)?jiān)L問(wèn):考試吧軟件水平考試欄目

            希望與更多網(wǎng)友交流,請(qǐng)進(jìn)入考試吧軟件水平考試論壇

            上一頁(yè)  [1] [2] [3] [4] 

            轉(zhuǎn)帖于:軟件水平考試_考試吧
            文章搜索  
            看了本文的網(wǎng)友還看了:
            軟件水平考試權(quán)威輔導(dǎo)教材: 訂書(shū)電話(huà):010-62168566  更多>>>
            網(wǎng)友評(píng)論
            昵 稱(chēng): *  評(píng) 分: 1分 2分 3分 4分 5分
            標(biāo)題:   匿名發(fā)表    (共有條評(píng)論)查看全部評(píng)論>>
            版權(quán)聲明 -------------------------------------------------------------------------------------
              如果軟件水平考試網(wǎng)所轉(zhuǎn)載內(nèi)容不慎侵犯了您的權(quán)益,請(qǐng)與我們聯(lián)系,我們將會(huì)及時(shí)處理。如轉(zhuǎn)載本軟件水平考試網(wǎng)內(nèi)容,請(qǐng)注明出處。
            關(guān)于本站  網(wǎng)站聲明  廣告服務(wù)  聯(lián)系方式  付款方式  站內(nèi)導(dǎo)航  客服中心  友情鏈接  考試論壇  網(wǎng)站地圖
            Copyright © 2004-2008 考試吧軟件水平考試網(wǎng) All Rights Reserved    
            中國(guó)科學(xué)院研究生院權(quán)威支持(北京) 電 話(huà):010-62168566 傳 真:010-62192699
            百度大聯(lián)盟黃金認(rèn)證  十佳網(wǎng)絡(luò)教育機(jī)構(gòu)  經(jīng)營(yíng)許可證號(hào):京ICP060677