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

唯C更漂亮

VC。。。。。。

  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  12 隨筆 :: 0 文章 :: 6 評論 :: 0 Trackbacks
(1)“我的程序都是對的,可結(jié)果不對”

想想你的周圍,是不是也有人說這樣的話?如果你也曾經(jīng)說過,那就此打住,不要再說這句話,因為這句話只會顯示說話者的無知。既然程序都是對的,那為什么結(jié)果不對?

(2)“程序=算法+數(shù)據(jù)結(jié)構(gòu)”

如果剛剛學(xué)完C語言,我們說這樣的話,完全可以理解,而且可以說是正確的。但是如果你是一位即將從事C/C++編程的程序員,那么很遺憾,這個說法只能判錯,殊不知,世界上還有另一種說法:

程序 = 對象 + 消息

“程序=算法+數(shù)據(jù)結(jié)構(gòu)”只對面向過程的語言(C)成立,而對面向?qū)ο蟮恼Z言(C++),則只能表述為“程序=對象+消息”。傳統(tǒng)的過程式編程語言以過程為中心以算法為驅(qū)動,面向?qū)ο蟮木幊陶Z言則以對象為中心以消息為驅(qū)動。這里的消息是廣義的,對象A調(diào)用了對象B的成員函數(shù),可看作對象A給B發(fā)消息。

(3)“程序編出來,運行正確就行了”

運行正確的程序并不一定是好程序,程序員時刻要牢記的一條就是自己寫的程序不僅是給自己看的,要讓別人也能輕易地看懂。很遺憾,許多的編程新手不能清晰地駕馭軟件的結(jié)構(gòu),對頭文件和實現(xiàn)文件的概念含糊不清,寫出來的程序可讀性很差。

C程序采用模塊化的編程思想,需合理地將一個很大的軟件劃分為一系列功能獨立的部分合作完成系統(tǒng)的需求,在模塊的劃分上主要依據(jù)功能。模塊由頭文件和實現(xiàn)文件組成,對頭文件和實現(xiàn)文件的正確使用方法是:

規(guī)則1 頭文件(.h)中是對于該模塊接口的聲明,接口包括該模塊提供給其它模塊調(diào)用的外部函數(shù)及外部全局變量,對這些變量和函數(shù)都需在.h中文件中冠以extern關(guān)鍵字聲明;

規(guī)則2 模塊內(nèi)的函數(shù)和全局變量需在.c文件開頭冠以static關(guān)鍵字聲明;

   規(guī)則3 永遠不要在.h文件中定義變量;

許多程序員對定義變量和聲明變量混淆不清,定義變量和聲明變量的區(qū)別在于定義會產(chǎn)生內(nèi)存分配的操作,是匯編階段的概念;而聲明則只是告訴包含該聲明的模塊在連接階段從其它模塊尋找外部函數(shù)和變量。如:



/*模塊1頭文件:module1.h*/
int a = 5; /* 在模塊1的.h文件中定義int a */
/*模塊1實現(xiàn)文件:module1 .c*/
#i nclude “module1.h” /* 在模塊1中包含模塊1的.h文件 */
/*模塊2實現(xiàn)文件: module2.c*/
#i nclude “module1.h” /* 在模塊2中包含模塊1的.h文件 */
/*模塊2 實現(xiàn)文件:module3 .c*/
#i nclude “module1.h” /* 在模塊3中包含模塊1的.h文件 */

以上程序的結(jié)果是在模塊1、2、3中都定義了整型變量a,a在不同的模塊中對應(yīng)不同的地址單元,這明顯不符合編寫者的本意。正確的做法是:

/*模塊1頭文件:module1.h*/
extern int a; /* 在模塊1的.h文件中聲明int a */
/*模塊1實現(xiàn)文件:module1 .c*/
#i nclude “module1.h” /* 在模塊1中包含模塊1的.h文件 */
int a = 5; /* 在模塊1的.c文件中定義int a */
/*模塊2 實現(xiàn)文件: module2 .c*/
#i nclude “module1.h” /* 在模塊2中包含模塊1的.h文件 */
/*模塊3 實現(xiàn)文件: module3 .c*/
#i nclude “module1.h”   /* 在模塊3中包含模塊1的.h文件 */

這樣如果模塊1、2、3操作a的話,對應(yīng)的是同一片內(nèi)存單元。

   規(guī)則4 如果要用其它模塊定義的變量和函數(shù),直接包含其頭文件即可。

許多程序員喜歡這樣做,當他們要訪問其它模塊定義的變量時,他們在本模塊文件開頭添加這樣的語句:

extern int externVar;

   拋棄這種做法吧,只要頭文件按規(guī)則1完成,某模塊要訪問其它模塊中定義的全局變量時,只要包含該模塊的頭文件即可。

(4)“數(shù)組名就是指針”

許多程序員對數(shù)組名和指針的區(qū)別不甚明了,他們認為數(shù)組名就是指針,而實際上數(shù)組名和指針有很大區(qū)別,在使用時要進行正確區(qū)分,其區(qū)分規(guī)則如下:

規(guī)則1 數(shù)組名指代一種數(shù)據(jù)結(jié)構(gòu),這種數(shù)據(jù)結(jié)構(gòu)就是數(shù)組;

   例如:

char str[10];
char *pStr = str;
cout << sizeof(str) << endl;
cout << sizeof(pStr) << endl;

   輸出結(jié)果為:

10
4

這說明數(shù)組名str指代數(shù)據(jù)結(jié)構(gòu)char[10]。

規(guī)則2 數(shù)組名可以轉(zhuǎn)換為指向其指代實體的指針,而且是一個指針常量,不能作自增、自減等操作,不能被修改;

char str[10];
char *pStr = str;
str++; //編譯出錯,提示str不是左值 
pStr++; //編譯正確

規(guī)則3 指向數(shù)組的指針則是另外一種變量類型(在WIN32平臺下,長度為4),僅僅意味著數(shù)組的存放地址;

規(guī)則4 數(shù)組名作為函數(shù)形參時,在函數(shù)體內(nèi),其失去了本身的內(nèi)涵,僅僅只是一個指針;很遺憾,在失去其內(nèi)涵的同時,它還失去了其常量特性,可以作自增、自減等操作,可以被修改。

例如:

void arrayTest(char str[])
{
cout << sizeof(str) << endl;   //輸出指針長度
    str++; //編譯正確
}
int main(int argc, char* argv[])
{
  char str1[10] = "I Love U";
  arrayTest(str1);
return 0;
}

   (5)“整形變量為32位”

整形變量是不是32位這個問題不僅與具體的CPU架構(gòu)有關(guān),而且與編譯器有關(guān)。在嵌入式系統(tǒng)的編程中,一般整數(shù)的位數(shù)等于CPU字長,常用的嵌入式CPU芯片的字長為8、16、32,因而整形變量的長度可能是8、16、32。在未來64位平臺下,整形變量的長度可達到64位。

長整形變量的長度一般為CPU字長的2倍。

在數(shù)據(jù)結(jié)構(gòu)的設(shè)計中,優(yōu)秀的程序員并不會這樣定義數(shù)據(jù)結(jié)構(gòu)(假設(shè)為WIN32平臺):

typedef struct tagTypeExample
{
unsigned short x;
unsigned int y;
}TypeExample;

   他們這樣定義:

#define unsigned short UINT16 //16位無符號整數(shù)
#define unsigned int UINT32 //32位無符號整數(shù)
typedef struct tagTypeExample
{
UINT16 x;
UINT32 y;
}TypeExample;

這樣定義的數(shù)據(jù)結(jié)構(gòu)非常具有通用性,如果上述32平臺上的數(shù)據(jù)發(fā)送到16位平臺上接收,在16位平臺上僅僅需要修改UINT16、UINT32的定義:

#define unsigned int UINT16 //16位無符號整數(shù)
#define unsigned long UINT32 //32位無符號整數(shù)

   幾乎所有的優(yōu)秀軟件設(shè)計文檔都是這樣定義數(shù)據(jù)結(jié)構(gòu)的。

   (6)“switch和if …else…可隨意替換”

switch語句和一堆if…else…的組合雖然功能上完全一樣,但是給讀者的感受完全不一樣。if…else…的感覺是進行條件判斷,對特例進行特別處理,在邏輯上是“特殊與一般”的關(guān)系,而switch給人的感覺是多個條件的關(guān)系是并列的,事物之間不存在特殊與一般的關(guān)系,完全“對等”。

譬如:

//分別對1-10的數(shù)字進行不同的處理,用switch
switch(num)
{
case 1:

case 2:

}
//對1-10之間的數(shù)字進行特殊處理,用if
if(num < 10 && num > 1)
{

}
else
{

}

許多時候,雖然不同的代碼可實現(xiàn)完全相同的功能,但是給讀者的感覺是完全不同的。譬如無條件循環(huán):

while(1)
{
}

   有的程序員這樣寫:

for(;
{
}

   這個語法沒有確切表達代碼的含義,我們從for(;看不出什么,只有弄明白for(;在C/C++語言中意味著無條件循環(huán)才明白其意。而不懂C/C++語言的讀者看到while(1)也可猜到這是一個無條件循環(huán)。

(7)“免得麻煩,把類里面的成員函數(shù)都搞成public算了”

許多人編C++程序的時候,都碰到這樣的情況,先前把某個成員函數(shù)定義成類的private/protected函數(shù),后來發(fā)現(xiàn)又要從外面調(diào)用這個函數(shù),就輕易地將成員函數(shù)改為public類型的。甚至許多程序員為了避免訪問的麻煩,干脆把自己添加的成員函數(shù)和成員變量都定義成public類型。

殊不知,這是一種規(guī)劃的失敗。在類的設(shè)計階段,我們就要很清晰地知道,這個類的成員函數(shù)中哪些是這個類的接口,哪些屬于這個類內(nèi)部的成員函數(shù)和變量。一般的準則是接口(public成員)應(yīng)在滿足需求的前提下盡可能簡單!

所以不要輕易地將private/protected成員改為public成員,真正的工作應(yīng)該在規(guī)劃階段完成。


posted on 2007-05-02 21:31 唯C程序猿 閱讀(176) 評論(0)  編輯 收藏 引用
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            中日韩午夜理伦电影免费| 一区二区亚洲精品国产| 一区二区三区视频观看| 亚洲精品国产精品国自产在线 | 亚洲乱码视频| 亚洲国产天堂网精品网站| 亚洲国产va精品久久久不卡综合| 亚洲第一天堂av| 日韩午夜在线视频| 亚洲专区一二三| 久久久一区二区三区| 农村妇女精品| 欧美日韩亚洲视频一区| 国产精品亚洲аv天堂网| 国产日韩在线看片| 亚洲国产精品一区制服丝袜| 亚洲精品免费在线播放| 亚洲视频第一页| 久久精品最新地址| 亚洲国产精品小视频| 中文国产成人精品| 久久伊伊香蕉| 国产精品视区| 亚洲国产精品精华液2区45| 亚洲一品av免费观看| 六月婷婷久久| 午夜国产一区| 欧美成人黑人xx视频免费观看| 欧美日韩国产色视频| 一区二区三区在线视频免费观看| 亚洲图片欧美午夜| 免费在线一区二区| 亚洲自啪免费| 欧美日韩免费观看中文| 在线播放日韩| 性欧美办公室18xxxxhd| 欧美激情按摩在线| 欧美国产精品人人做人人爱| 亚洲欧洲日韩在线| 欧美亚洲三级| 国产精品日韩电影| 亚洲伦伦在线| 欧美成人精品不卡视频在线观看| 亚洲视频在线观看免费| 欧美大片国产精品| 一区二区三区在线免费视频| 亚洲欧美日韩国产综合在线| 亚洲国产毛片完整版 | 亚洲激情在线视频| 久久久久久香蕉网| 国产日产欧产精品推荐色 | 欧美日本在线观看| 尤物视频一区二区| 久久一区中文字幕| 欧美中文字幕视频| 国产一区二区你懂的| 亚洲欧美视频| 在线视频你懂得一区| 欧美午夜理伦三级在线观看| 一二三四社区欧美黄| 亚洲欧洲精品成人久久奇米网| 欧美一区国产一区| 国产一区二区欧美| 久久婷婷国产综合国色天香| 亚洲男女自偷自拍| 国产精品黄色在线观看| 亚洲欧美日产图| 亚洲女同在线| 国产亚洲欧美一区在线观看| 久久精品2019中文字幕| 欧美在线观看视频在线 | 亚洲一区二区成人在线观看| 日韩图片一区| 欧美日韩亚洲三区| 欧美中文字幕在线播放| 久久精品中文字幕一区二区三区| 狠狠干综合网| 亚洲国产视频一区| 国产精品99一区| 久久激情久久| 欧美成人午夜剧场免费观看| 一区二区欧美日韩视频| 中文在线资源观看网站视频免费不卡| 国产精品视频免费观看www| 久久精品三级| 免费欧美日韩国产三级电影| 一区二区三区欧美在线观看| 中文日韩在线视频| 国内久久视频| 亚洲精品在线观| 国产深夜精品| 欧美不卡高清| 国产精品毛片va一区二区三区| 欧美三日本三级少妇三99| 午夜精品久久久| 久久久www免费人成黑人精品 | 亚洲女ⅴideoshd黑人| 国产亚洲精品资源在线26u| 免费h精品视频在线播放| 欧美久久一区| 久久久久九九视频| 欧美精品精品一区| 久久久久国产精品午夜一区| 暖暖成人免费视频| 久久精品国产免费看久久精品| 欧美r片在线| 久久国产精品一区二区三区| 欧美成人午夜激情视频| 欧美在线精品一区| 欧美日韩福利视频| 久久久精品2019中文字幕神马| 欧美精品免费视频| 蜜臀99久久精品久久久久久软件| 国产精品久久二区| 亚洲精品看片| 亚洲精品免费一二三区| 乱码第一页成人| 久久婷婷国产麻豆91天堂| 国产精品推荐精品| 一区二区三区日韩欧美| 一本色道久久综合亚洲精品不 | 欧美成人午夜激情在线| 久久久精品久久久久| 欧美少妇一区| 亚洲精品一区二区三区99| 在线日韩av永久免费观看| 亚洲欧美国产精品va在线观看 | 亚洲电影观看| 久久国产精品99国产精| 久久国产精品久久w女人spa| 国产精品久久中文| 亚洲天堂av图片| 亚洲欧美中文字幕| 国产精品你懂得| 亚洲一区免费网站| 亚洲午夜免费视频| 欧美网站在线观看| 激情久久综艺| 久久影音先锋| 一区二区在线看| 久久精品夜色噜噜亚洲aⅴ| 久久精品国产免费观看| 久久九九免费| 性色av一区二区三区红粉影视| 国产精品二区在线| 亚洲免费人成在线视频观看| 欧美一区二区三区免费观看视频| 国产精品丝袜xxxxxxx| 久久精品2019中文字幕| 亚洲一区久久| 久久久高清一区二区三区| 亚洲欧美一区二区原创| 国产精品免费在线| 欧美在线一级va免费观看| 亚洲国产高清自拍| 你懂的成人av| 一本大道av伊人久久综合| 香蕉久久夜色精品国产| 国产日韩欧美自拍| 久久只有精品| 一区二区国产精品| 久久综合九色综合久99| 亚洲精品综合| 国产情侣一区| 99视频一区二区| 欧美中文字幕第一页| 亚洲国产天堂久久综合| 亚洲综合国产| 在线播放豆国产99亚洲| 欧美性猛交xxxx乱大交蜜桃| 久久精品成人| 亚洲最新在线| 欧美jjzz| 亚洲一区二区精品视频| 韩国欧美一区| 欧美性片在线观看| 亚洲精品乱码久久久久| 免费看成人av| 亚洲女性裸体视频| 亚洲激情国产精品| 国产精品久久久久av免费| 欧美 亚欧 日韩视频在线| 亚洲一区二区三| 中文在线资源观看视频网站免费不卡| 好看的日韩视频| 国产精品天天摸av网| 欧美理论在线播放| 久久久亚洲综合| 欧美一乱一性一交一视频| 久色婷婷小香蕉久久| 亚洲视频视频在线| 日韩亚洲一区在线播放| 欧美xx69| 欧美在线欧美在线| 亚洲在线中文字幕| 一本色道久久88综合日韩精品 | 久热综合在线亚洲精品| 亚洲永久在线观看| 一道本一区二区| 亚洲国产精品一区制服丝袜|