青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-60  評論-98  文章-0  trackbacks-0
我和充斥臭味代碼的戰爭
by leetaolion 2008-01-12
從去年8月份到現在,我一直在從事一個261k行代碼的項目(不含空行和注釋)。
其中由我本人編寫的代碼10.9k行(不含空行和注釋,我本人所寫的注釋大約1/8有效代碼行,屬于比較少的)。
其他模塊注釋非常少,只在接口文件聲明虛接口的時候會有一行注釋,實現文件中幾乎沒有注釋,大部分文件連文件頭都沒有。
在我加入小組之前,小組是穩定的,每人負責幾個模塊,不采用TDD,依靠的是每日集成。每日的目標是:可以Build的代碼。
我加入之后,起初做些邊邊角角的工作。這樣的日子大概持續了1個半月的樣子。然后在一個午睡并沒有完全醒來的狀態下,接手了一個核心模塊DataMgr_Module,這個模塊管理所有的計算的輸出結果。
一開始對工作的估計過于樂觀,認為1個月就可以搞定。接手之后才發現,原來的DataMgr_Module其實是兩個module,小組的老大和另外一位同事對于DataMgr是各自為政,每個人都有一份自己的數據結構和管理方法。由于同事同時負責多個上層模塊的開發,所以,DataMgr_Module和上層完全耦合在一起,DataMgr_Module的大部分功能都分布在各個上層模塊之中,每個上層模塊重復實現的這些功能,如果有一個功能需要更新,那么就要改動所有的上層模塊。所謂的DataMgr_Module只不過是把自己的所有接口都公布出來的任人欺負的家伙,公布的大部分接口都應該是私有接口。DataMgr_Module就像是個受氣包,Manager變成了Clark。
首先要做的是恢復Manager的地位。統一數據結構,統一傳輸協議,從上層模塊收回所有接口實現,規范業務流程,private所有私有接口和成員變量。Manager就該有個Manager的樣子。
模塊做到最后,我的感受是越到集成測試的時候,我就會越想念TDD。為什么呢?
DataMgr_Module一開始就采用了TDD。知道所有的PR會上確認的接口都完成,并通過了測試用例。單元測試做的并不充分,因為當時沒有采用任何的測試用例方法。只是憑借自己對模塊可能存在的缺陷進行了測試。整個單元測試的過程與其說是在測試,倒不如說是在驗證,過程中對于錯誤的恐懼,使測試用例漏洞百出,覆蓋效果是比較差勁的。另外一個原因是,TDD是把測試用例當作用戶手冊的,但是,同事們根本不在意你的測試用例。別說測試用例了,有時候連注釋都懶得看,有問題直接溝通,人就是一部用戶手冊。溝通解決問題,是積極高效的,有時候是重復的。另外一個原因就是,注釋的模式不好,常常要更新同樣的3個不同位置的注釋。之前健健告訴我,應該把這看成是必須做好的工作,就好了。但是我人比較懶,需要個好辦法,變3次為1次。(目前也沒有找到好辦法,因為我壓根就沒有怎么好好找過。)
所以我常常在想,怎么樣才能讓TDD深入我的日常工作呢?
TDD的老爹Kent說如果已經有可以運行的代碼,這時候是不適合引入TDD的。對已經可以運行的261k行代碼重新寫測試用例,怕是要出人命的。我想Kent老爹說的是老代碼從新TDD,言之有理,對于一個成年人你來T他的小DD,當然就要踢出大事情來。但是對于一些新模塊,或者說是老模塊需要徹底修改(幾乎全部拋棄)的時候,年輕人嗎,從小開始T他的小DD,慢慢培養,說不定能T出一個會鐵襠功的模塊來,到時候豈不是天下無敵了。
正因為DataMgr_Module從小開始TDD,集成測試的時候,需要增加一個接口(主要用來提高模塊的易用性)的時候,從提出需要到拆入,不過5分鐘,令用戶滿意的嘴都合不攏了。為什么啊?因為TDD了。
嘴上無毛,辦事不牢。調試除了問題,幾位用戶首先想到的是DataMgr_Module出了問題,肯定要找我。10次有8次是因為用戶沒有按照事先約定的協議進行操作引起的錯誤。為什么啊?因為TDD了。
當然也有T的不好的時候。一個哥們把DWORD編碼的模塊,內部全部用int代替,因為他自認不會有超過0x7FFFFFFF個數據要處理。好嘛,新的規則把編碼的首位置1,0區分兩類不同數據,每次操作全是失敗。上層模塊(DataMgr_Module也是相對的上層模塊)拿著這哥們的DLL調的天昏地暗,也丈二和尚摸不著頭。沒辦法,把老兄的的代碼搞過來研究一下,原來老兄偷懶,把所有的字符串全部中轉成了int(因為沒有現成的字符串到雙字的轉換函數),他T到最后也沒把這個臭蟲給T出來。Shit,害死人不抵命的啊。(于是有了上一篇瀏覽量不高的字符串轉雙字方法。)
DataMgr_Module出生,使用使得部分Module因此癱瘓,老大不得已,注釋掉了大量的代碼,最上面打上“TODO”的MsgBox,每次運行的時候,大家都會想起我。
當然,最后這些次生修改工作必須由我來承擔的。老大不得已,開辟了部分原來限制訪問代碼的拆出。不看則以,一看暈菜。老Clark的臭味綿延的如此之遠,上至業務模塊,下至基礎模塊,無一不沾腥帶臭。
有一些代碼甚至到了令人發指的地步,老大Z寫的一個短短20行的函數,為了使用方便封裝成n個宏函數,并對其中的部分函數再次#define,用戶老大S為了方便,在此基礎上又#define了一次,不知怎么回事,老大S換了個名字又是一次#define。兩位老大在開發理念上的分歧在這短短的幾行代碼之中體現的淋漓盡致。Sigh,何必呢。(注:老大S是以每日Build通過為目標,效率至上。老大Z是一完美主義者,每日Build通過是他的目標之一,更注重Execute的代碼。兩位老大的共同點技術功力深厚,另外就是從未及時Meet過DeadLine。我本人更傾向于老大Z的開發理念,不過現在是老大S的小弟。)
看來兩位老大都有問題,到底以啥子為目標呢?
看看微軟的一天
 每日構造: daily build (mid-night)
 開發: 解決blocking bugs, 實現功能, check-out, code review, check-in
 測試: BVT, 使用測試用例進行測試
 項目經理/組長: 專家會診
我們的差距在哪?
在測試上。目前團隊大部分成員對于測試用例的理解是:由測試組在系統測試的時候,按照需求說明書寫出的測試用例。而單元測試的測試用例幾乎就沒有。咋整?這不就是TDD解決的問題嗎。
對于加入工程組的新模塊,開發初期需要執行TDD,測試用例,測試用例覆蓋,到什么程度呢,如果是自己寫,就寫到自己不心虛為止吧,如果有人專門寫,那就寫到此人自己沒有困惑為止吧。
每次Debug的代價
每次Debug,需要啟動一次HostProgram,加載所有模塊。鼠標點點,鍵盤按按,才走到自己想要的斷點。每次這么搞,都感覺自己傻瓜一樣。自動化測試測到哪,我現在的能力只能做沒有界面的單元測試。界面測試已經提了需求,等著老大們開講。
對隊友離開的恐懼:
我有時候會突然冒出這樣的念頭:如果oy,或者xa離開了,我們怎么辦?項目會不會因此而停掉。結論是:項目是不會停掉的,因為我們在一個大艦隊中,一個小舢板部分水手的離開,老大不會坐視,新的水手稍后就到。但,進一步的進展是舉步維艱的。大量沒有注釋的代碼,足以讓每一個新成員崩潰。沒有注釋的代碼,是隊員變得不可或缺,人是安全的。這只是我以最壞的惡意來揣測不注釋代碼的作者。或許是趕時間吧,之前幾個版本的發布都顯得很精彩,不過軟件的內部都是一鍋鹵煮火燒。這種看起來很美,會在用戶的手里土崩瓦解。如果是這樣的話,我們因此被團隊拋棄,都不會再有團隊來接納。在此之前,還是T自己狠一點吧。
posted on 2008-01-12 13:00 創建更好的解決方案 閱讀(2282) 評論(26)  編輯 收藏 引用 所屬分類: TDDXP敏捷心路歷程閑話連篇軟件測試軟件設計

評論:
# re: 我和充斥臭味代碼的戰爭 2008-01-12 13:57 | <a href=http://minidx.com>minidxer</a>
這樣的項目,做起來要累死人了……  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-12 16:26 | LOGOS
這樣的情形,可以試試《修改代碼的藝術》(《Working Effectively with Legacy Code》)里面介紹的東西,應該會有幫助。
祝你好運  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-12 21:35 | K120
一個模塊10.9k行的代碼,這個模塊劃分的也夠大了。
“大量沒有注釋的代碼,足以讓每一個新成員崩潰”。夸張了吧。  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-12 21:45 | K120
不好意思,說錯話了,我自己一個模塊的代碼也有11個CPP文件,平均每個文件超過600行,大致也在6.5K行代碼,還沒完成呢  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-13 08:33 | 小笨象
這時候,注釋是很重要的了。
我自己寫的程序,怎么也有10萬行了。不敢忘了寫注釋,怕自己轉頭就忘了。
還好,我公司寫的程序,注釋還多,接手的人基本上不問我怎么做的,看注釋就行了。嗯。。。。可能是因為人家聰明吧。。。。。  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-13 14:04 | 西門有悔
暈哦.我一同事寫了一個模塊,6K多代碼,沒有一行注釋,而且通篇是:
testID, devicenumber,Int? Long? Unsigned Long?....

我直接暈倒了.這樣下去真的會死人的  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-13 15:14 | eXile
http://www.javaeye.com/topic/6294
關于文檔和注釋的討論  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-13 15:17 | eXile
http://www.javaeye.com/topic/5876
關于文檔和注釋的討論  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-14 08:31 | 創建更好的解決方案
@LOGOS
書中講的大都是以有測試的系統為前提,但是以前老前輩們寫的程序,連注釋都少的可憐,基本上不考慮封裝,改起來真是痛苦啊!

  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-14 08:33 | 創建更好的解決方案
@小笨象
我剛工作半年多點,代碼寫的少了一些。到了10萬行的時候,或許會提高一下層次。  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-14 12:17 | 創建更好的解決方案
@&lt;a href=http://minidx.com&gt;minidxer&lt;/a&gt;
你可是我見過的最細心的管理員啊,呵呵
  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-14 16:18 | LOGOS
@創建更好的解決方案
書里面講的是以無測試的系統為前提的,和你理解的不太一樣  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-14 19:15 | 小笨象
寫代碼,經驗是很重要的。
多寫,多看,注釋不要忘。這就足夠了。
慢慢的你就知道了。
如果有人教你,那才能提高得快。但不能事事問人,問就問最強的。。。。。  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-14 23:54 | 菌子
### 我負責的模塊,10幾年了,10k行,我都怕動。  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-15 08:01 | 創建更好的解決方案
@菌子
好的模塊你動它干嘛?
有臭味的模塊,不動,留它干嘛?  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-15 14:04 | 菌子
額。。 如果這個代碼已經在十年間添加和修改了無數次,充滿了臭味,但是仍然良好的工作。 其中很多定義,用法你根本不知道原因, 你如何修改它?   回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-15 22:01 | 創建更好的解決方案
@菌子
那要看你對代碼的要求了。
代碼能工作,沒錯。
但是這是基本的要求,可擴展性、可移植性、可測試性也要考慮啊。
這些指標在團隊中尤為重要。  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-17 11:49 | 小四
個人感覺10K行的代碼,下決心花力氣還是可以讀通的。再多了,就很是觸霉頭。  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-21 22:51 | abettor
早就發現,注釋是一種美德。
所幸,自己天良未泯,好歹有1/10的注釋。

我的Team里其他一些兄弟相比之下就殘忍了一些。有為老兄,一個函數寫了1798行,沒有任何注釋,局部變量沒有任何語義,都是“h”、“f”之類。后來,他走了,留下的幾個人哭了。  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-22 13:53 | 歲月流冰
我現在工作的模塊有35個cpp文件,n個h文件,cpp文件幾乎每個都在8k行以上,而且注釋極少。很郁悶。  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-22 17:29 | 創建更好的解決方案
@歲月流冰
呵呵,8k行是不是太重量了些。
我看到2k行以上的代碼都會心有戚戚焉。
所以都控制在2k以內吧(或許我們的項目規模就不夠大吧)。
  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2008-01-22 17:33 | 創建更好的解決方案
@abettor
割了吧,都燒焦了。
  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭[未登錄] 2008-01-25 15:31 | 汪江濤
臭味?吐啊吐的就習慣了  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2009-05-26 17:46 | zsggsz
團隊規則:沒有注釋代碼的人就主動離開!  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2010-08-06 13:32 | stepinto
@K120
我現在維護的代碼,300多k,至少4,5個cpp都是在15000行左右的,基本沒有注釋,大量的Duplicated code,Long method,Large class  回復  更多評論
  
# re: 我和充斥臭味代碼的戰爭 2010-08-06 13:33 | stepinto
這絕對是項目管理問題@abettor
  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美激情精品| 亚洲国产免费| 狠狠爱综合网| 狠狠色狠狠色综合人人| 国内精品美女在线观看| 在线成人国产| 亚洲欧洲综合另类| 一区二区日韩精品| 亚洲欧美在线网| 久久久久成人精品免费播放动漫| 久久狠狠一本精品综合网| 久久久青草婷婷精品综合日韩| 久久免费视频在线| 亚洲黄色av| 亚洲一区二区三区视频| 欧美一区二区日韩| 欧美黄色一区| 国产午夜精品美女毛片视频| 影音先锋国产精品| 亚洲一区二区在| 欧美aaaaaaaa牛牛影院| 一本色道久久综合亚洲精品婷婷| 亚洲女性喷水在线观看一区| 美女视频黄 久久| 国产日产欧美精品| 一区二区三区久久| 蜜桃av综合| 先锋影音国产精品| 欧美视频亚洲视频| 亚洲国产精品高清久久久| 亚洲欧美日韩电影| 亚洲国产精品www| 久久www成人_看片免费不卡| 国产精品美腿一区在线看| 亚洲精品美女在线观看| 久热精品视频| 亚洲三级电影在线观看 | 亚洲欧美在线aaa| 欧美视频精品一区| 亚洲蜜桃精久久久久久久| 久久人91精品久久久久久不卡| 一区二区三区国产在线观看| 欧美日韩91| 正在播放欧美视频| 亚洲精品乱码久久久久久蜜桃麻豆| 看欧美日韩国产| 亚洲国产精品一区二区三区| 老司机aⅴ在线精品导航| 久久精品国产清高在天天线 | 欧美大片在线观看一区二区| 久久久激情视频| 亚洲激情成人| 一区二区三区国产精华| 国产欧美日韩高清| 欧美成人dvd在线视频| 欧美女激情福利| 久久精品一区二区国产| 美女主播精品视频一二三四| 在线亚洲+欧美+日本专区| 亚洲一区二区av电影| 在线观看亚洲a| 亚洲欧美www| 国产亚洲欧美一区二区三区| 亚洲国产成人精品女人久久久| 欧美色大人视频| 久久综合久久综合久久| 欧美久久久久中文字幕| 久久久久亚洲综合| 欧美日韩1区2区3区| 久热精品视频在线| 国产精品乱码一区二三区小蝌蚪| 另类酷文…触手系列精品集v1小说| 欧美成人资源网| 麻豆av福利av久久av| 国产精品一二三四| 99国产精品国产精品久久 | 日韩亚洲国产欧美| 亚洲精品久久久久久下一站| 久久精品九九| 久久精品国产清自在天天线| 国产精品成人免费| 日韩亚洲国产欧美| 一本大道久久a久久综合婷婷 | 久久av红桃一区二区小说| 欧美日韩第一页| 日韩一区二区电影网| 99在线|亚洲一区二区| 免费亚洲网站| 亚洲日本中文| 亚洲欧美国产精品va在线观看 | 一区二区动漫| 国产欧美日韩在线播放| 亚洲大片免费看| 一本一本久久| 欧美午夜理伦三级在线观看| 在线一区二区日韩| 欧美一区国产二区| 激情综合视频| 欧美连裤袜在线视频| 中文在线不卡视频| 久久久久久久成人| 亚洲人成啪啪网站| 国产精品成人va在线观看| 亚洲欧美变态国产另类| 欧美91视频| 亚洲一区二区在线观看视频| 国产日韩欧美91| 欧美精品三级日韩久久| 亚洲影院色无极综合| 欧美激情第1页| 欧美诱惑福利视频| 日韩一区二区精品葵司在线| 国产精品女人久久久久久| 久久久免费观看视频| 一级日韩一区在线观看| 欧美成人精品福利| 99热免费精品在线观看| 国产精品裸体一区二区三区| 蜜桃精品久久久久久久免费影院| 日韩午夜电影在线观看| 你懂的视频一区二区| 先锋影音国产精品| 亚洲色图综合久久| 亚洲精品亚洲人成人网| 伊人一区二区三区久久精品| 欧美午夜不卡在线观看免费| 欧美成人一区在线| 麻豆成人精品| 久久综合狠狠| 久久中文字幕导航| 久久免费视频这里只有精品| 欧美在线三区| 亚洲一区二区三区中文字幕在线| 亚洲日本va午夜在线影院| 欧美激情自拍| 91久久极品少妇xxxxⅹ软件| 亚洲国产成人av在线| 欧美激情亚洲视频| 亚洲精品网站在线播放gif| 欧美高清在线观看| 亚洲精品女av网站| 亚洲黄一区二区三区| 亚洲午夜精品17c| 羞羞答答国产精品www一本| 欧美一级理论片| 久久只有精品| 国产精品久久久久久av福利软件| 国产精品久久久久9999高清| 国产一区二区三区在线观看精品| 国产亚洲激情在线| 亚洲国产成人精品久久久国产成人一区 | 国产精品国产一区二区| 国产精品视频1区| 亚洲国产成人久久综合一区| 99pao成人国产永久免费视频| 亚洲影视在线| 蜜臀av国产精品久久久久| 亚洲精品在线电影| 校园春色国产精品| 亚洲精品少妇网址| 亚洲欧美日韩国产成人精品影院| 久久激情视频| 欧美性猛片xxxx免费看久爱| 国产在线视频欧美| 亚洲女女女同性video| 免费av成人在线| 欧美一级专区免费大片| 欧美经典一区二区| 在线日本成人| 久久久久久黄| 欧美中文在线免费| 国产九区一区在线| 亚洲欧美日韩国产一区二区| 欧美激情四色| 欧美国产日韩一区| 1204国产成人精品视频| 久久在线免费观看视频| 欧美一级在线视频| 国内精品伊人久久久久av影院| 午夜亚洲性色视频| 亚洲男女自偷自拍| 韩国欧美一区| 欧美黑人多人双交| 欧美岛国在线观看| 在线综合欧美| 久久露脸国产精品| 一区二区三区四区精品| 一区二区成人精品 | 欧美激情精品久久久久久蜜臀| 欧美激情精品久久久久| 亚洲一区二区四区| 久久久www成人免费无遮挡大片| 亚洲国产日韩一区| 亚洲综合好骚| 亚洲欧洲日产国码二区| 久久天堂精品| 欧美18av| 另类天堂视频在线观看| 欧美激情视频一区二区三区免费| 欧美一区二区三区在线观看|