程序員:請(qǐng)不要輕視我們的過去
這是當(dāng)年開發(fā)的一個(gè)煤炭安全監(jiān)控軟件里增加新測點(diǎn)的函數(shù)。如果在當(dāng)年看這段代碼,感覺這應(yīng)該是一段挺不錯(cuò)的代碼,比如:注釋很多,幾乎每行都有注釋;匈牙利命名法,使用像lp、w這樣的前綴;結(jié)構(gòu)、數(shù)組、宏定義,看起來都是有板有眼。
- //-----------------------------------------------------------------------------
 - // 函數(shù):NewPoint
 - // 功能:分配一個(gè)測點(diǎn)定義緩沖區(qū)。
 - // 入口參數(shù):
 - // lpPNum 測點(diǎn)號(hào)指針。
 - // 出口參數(shù):
 - // 如成功,返回在測點(diǎn)定義表中的偏移;如失敗,返回0xffff。
 - //-----------------------------------------------------------------------------
 - WORD NewPoint(LPCSTR lpPNum)
 - {
 - WORD i;
 - LPTPOINT lpTmpPt;
 - // 在測點(diǎn)定義表中找空的緩沖區(qū)
 - for (i=0;i<PtTab.wCount;i++) if (PtTab.lpPt[i].tpDel) break;
 - if (i==PtTab.wCount) {
 - // 如未找到,則判斷測點(diǎn)數(shù)是否已到***值,如已到,則返回失敗
 - if (PtTab.wCount+1>MAXPOINT) return(0xffff);
 - // 如未找到***值,則測點(diǎn)總數(shù)加1。即在測點(diǎn)定義表的***追加一個(gè)緩沖區(qū)
 - PtTab.wCount++;
 - }
 - // 初始化緩沖區(qū)
 - lpTmpPt=&PtTab.lpPt[i];
 - // 將刪除標(biāo)志(即緩沖區(qū)空標(biāo)志)置1,作為后面具體定義時(shí)區(qū)分增加與修改的標(biāo)志,
 - // 如是修改,則此標(biāo)志必為0
 - lpTmpPt->tpDel=1;
 - // 拷貝測點(diǎn)號(hào)到緩沖區(qū)
 - lstrcpy(lpTmpPt->tpNum,lpPNum);
 - // 將前一此操作測點(diǎn)的定義復(fù)制到緩沖區(qū)
 - lstrcpy(lpTmpPt->tpName,HistPt.tpName);
 - lpTmpPt->tpType=HistPt.tpType;
 - lpTmpPt->tpOp=HistPt.tpOp;
 - // 賦缺省的狀態(tài)與數(shù)值
 - lpTmpPt->tpState=PS_SUSP;
 - lpTmpPt->tpRValue=0;
 - lpTmpPt->tpDValue=0;
 - // 置缺省的狀態(tài)變化時(shí)間為當(dāng)前時(shí)間
 - _fmemcpy(&lpTmpPt->tpTime,&Time,sizeof(SYSTIME));
 - // 將偏移值返回
 - return(i);
 - }
 
時(shí)間已經(jīng)過去十幾年了,計(jì)算機(jī)系統(tǒng)、開發(fā)語言、設(shè)計(jì)思想都有了很大轉(zhuǎn)變,現(xiàn)在要寫一段同樣功能的代碼,可能完全不同了。
***的變化應(yīng)該是面向?qū)ο蠹夹g(shù)的應(yīng)用,測點(diǎn)和測點(diǎn)表都會(huì)從struct變?yōu)閏lass,測點(diǎn)數(shù)組可能會(huì)用std::vector或std::list代替,并且用new來動(dòng)態(tài)分配,宏定義也會(huì)換成常量或枚舉。而上面這個(gè)創(chuàng)建新測點(diǎn)的函數(shù),也會(huì)被封裝到測點(diǎn)表這個(gè)類中。面向?qū)ο蠹夹g(shù)改變了我們思考和實(shí)踐的方式,而且這個(gè)改變作用是巨大的。
再有就是一些設(shè)計(jì)思想的轉(zhuǎn)變,比如對(duì)注釋的看法。以前,注釋多可能意味著可讀性強(qiáng)。但《重構(gòu)》一書中說:“你看到一段代碼有著長長的注釋,然后發(fā)現(xiàn),這些注釋之所以存在乃是因?yàn)榇a很糟糕。”再看看上面這段代碼,前半段,其實(shí)是查找一個(gè)空的測點(diǎn)位置,完全可以用Extract Method(提煉函數(shù))重構(gòu)方法將其移入另外一個(gè)函數(shù),并給其一個(gè)準(zhǔn)確的命名,而不需要注釋。后半段,“代碼已經(jīng)清楚說明了一切,注釋已經(jīng)變得多余了。”
匈牙利命名法,已成為爭議***的命名法,其類型冗余常常大于它所帶來的收益。它來自微軟的一名匈牙利程序員,但現(xiàn)在微軟的.Net和它的編程語言中,微軟更換了這一法則,在C#中以駱駝命名法和帕斯卡命名法居多。
計(jì)算機(jī)系統(tǒng)的提升也改變著程序。早年16位OS上編程需要區(qū)分遠(yuǎn)指針和近指針,但現(xiàn)在32位環(huán)境下,C++指針變量前綴一般都是p,很少見到lp。
技術(shù)在進(jìn)步,編程思想在轉(zhuǎn)變,人的思維也在不斷更新。也許再過十幾年,現(xiàn)在聽都沒有聽說過的新技術(shù)會(huì)大行其道,你回頭再看看現(xiàn)在的代碼,可能也會(huì)有像我今天的感覺。但無論怎樣,請(qǐng)不要輕視我們的過去,因?yàn)闆]有過去的積累,就沒有今天的進(jìn)步。
 
原文鏈接:http://www.cnblogs.com/wanghui9072229/archive/2011/04/25/2028793.html
【編輯推薦】















 
 
 



 
 
 
 