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