freepeople性欧美熟妇, 色戒完整版无删减158分钟hd, 无码精品国产vα在线观看DVD, 丰满少妇伦精品无码专区在线观看,艾栗栗与纹身男宾馆3p50分钟,国产AV片在线观看,黑人与美女高潮,18岁女RAPPERDISSSUBS,国产手机在机看影片

正文內(nèi)容

高質(zhì)量cc++編程講義-資料下載頁

2025-05-03 00:40本頁面
  

【正文】 工具可以對(duì)const常量進(jìn)行調(diào)試,但是不能對(duì)宏常量進(jìn)行調(diào)試。 l l 【規(guī)則521 】在C++ 程序中只使用const常量而不使用宏常量,即const 常量完全取代宏常量。 常量定義規(guī)則l l 【規(guī)則531】需要對(duì)外公開的常量放在頭文件中,不需要對(duì)外公開的常量放在定義文件的頭部。為便于管理,可以把不同模塊的常量集中存放在一個(gè)公共的頭文件中。l l 【規(guī)則532】如果某一常量與其它常量密切相關(guān),應(yīng)在定義中包含這種關(guān)系,而不應(yīng)給出一些孤立的值。例如:const float RADIUS = 100。const float DIAMETER = RADIUS * 2。 類中的常量有時(shí)我們希望某些常量只在類中有效。由于define定義的宏常量是全局的,不能達(dá)到目的,于是想當(dāng)然地覺得應(yīng)該用const 修飾數(shù)據(jù)成員來實(shí)現(xiàn)。const數(shù)據(jù)成員的確是存在的,但其含義卻不是我們所期望的。const 數(shù)據(jù)成員只在某個(gè)對(duì)象生存期內(nèi)是常量,而對(duì)于整個(gè)類而言卻是可變的,因?yàn)轭惪梢詣?chuàng)建多個(gè)對(duì)象,不同的對(duì)象其const數(shù)據(jù)成員的值可以不同。 不能在類聲明中初始化const數(shù)據(jù)成員。以下用法是錯(cuò)誤的,因?yàn)轭惖膶?duì)象未被創(chuàng)建時(shí),編譯器不知道SIZE的值是什么。 class A {… const int SIZE = 100。 // 錯(cuò)誤,企圖在類聲明中初始化const數(shù)據(jù)成員 int array[SIZE]。 // 錯(cuò)誤,未知的SIZE }。 const數(shù)據(jù)成員的初始化只能在類構(gòu)造函數(shù)的初始化表中進(jìn)行,例如 class A {… A(int size)。 // 構(gòu)造函數(shù) const int SIZE 。 }。 A::A(int size) : SIZE(size) // 構(gòu)造函數(shù)的初始化表 { … } A a(100)。 // 對(duì)象 a 的SIZE值為100 A b(200)。 // 對(duì)象 b 的SIZE值為200 怎樣才能建立在整個(gè)類中都恒定的常量呢?別指望const數(shù)據(jù)成員了,應(yīng)該用類中的枚舉常量來實(shí)現(xiàn)。例如 class A {… enum { SIZE1 = 100, SIZE2 = 200}。 // 枚舉常量 int array1[SIZE1]。 int array2[SIZE2]。 }。 枚舉常量不會(huì)占用對(duì)象的存儲(chǔ)空間,它們?cè)诰幾g時(shí)被全部求值。枚舉常量的缺點(diǎn)是:它的隱含數(shù)據(jù)類型是整數(shù),其最大值有限,且不能表示浮點(diǎn)數(shù)(如PI=)。 第6章函數(shù)設(shè)計(jì)函數(shù)是C++/C 程序的基本功能單元,其重要性不言而喻。函數(shù)設(shè)計(jì)的細(xì)微缺點(diǎn)很容易導(dǎo)致該函數(shù)被錯(cuò)用,所以光使函數(shù)的功能正確是不夠的。本章重點(diǎn)論述函數(shù)的接口設(shè)計(jì)和內(nèi)部實(shí)現(xiàn)的一些規(guī)則。函數(shù)接口的兩個(gè)要素是參數(shù)和返回值。C語言中,函數(shù)的參數(shù)和返回值的傳遞方式有兩種:值傳遞(pass by value)和指針傳遞(pass by pointer)。C++ 語言中多了引用傳遞(pass by reference)。由于引用傳遞的性質(zhì)象指針傳遞,而使用方式卻象值傳遞,初學(xué)者常常迷惑不解,容易引起混亂,“引用與指針的比較 ”。 參數(shù)的規(guī)則l l 【規(guī)則611】參數(shù)的書寫要完整,不要貪圖省事只寫參數(shù)的類型而省略參數(shù)名字。如果函數(shù)沒有參數(shù),則用void填充。例如:void SetValue(int width, int height)。 // 良好的風(fēng)格void SetValue(int, int)。 // 不良的風(fēng)格float GetValue(void)。 // 良好的風(fēng)格float GetValue()。 // 不良的風(fēng)格 l l 【規(guī)則612】參數(shù)命名要恰當(dāng),順序要合理。例如編寫字符串拷貝函數(shù)StringCopy ,它有兩個(gè)參數(shù)。如果把參數(shù)名字起為str1和str2,例如void StringCopy(char *str1, char *str2)。那么我們很難搞清楚究竟是把str1拷貝到str2 中,還是剛好倒過來。可以把參數(shù)名字起得更有意義,如叫strSource和strDestination。這樣從名字上就可以看出應(yīng)該把 strSource拷貝到strDestination。還有一個(gè)問題,這兩個(gè)參數(shù)那一個(gè)該在前那一個(gè)該在后?參數(shù)的順序要遵循程序員的習(xí)慣。一般地,應(yīng)將目的參數(shù)放在前面,源參數(shù)放在后面。如果將函數(shù)聲明為:void StringCopy(char *strSource, char *strDestination)。別人在使用時(shí)可能會(huì)不假思索地寫成如下形式:char str[20]。StringCopy(str, “Hello World”)。 // 參數(shù)順序顛倒 l l 【規(guī)則613】如果參數(shù)是指針,且僅作輸入用,則應(yīng)在類型前加const,以防止該指針在函數(shù)體內(nèi)被意外修改。例如:void StringCopy(char *strDestination,const char *strSource)。 l l 【規(guī)則614】如果輸入?yún)?shù)以值傳遞的方式傳遞對(duì)象,則宜改用 “const amp?!狈绞絹韨鬟f,這樣可以省去臨時(shí)對(duì)象的構(gòu)造和析構(gòu)過程,從而提高效率。 178。 178。 【建議611】避免函數(shù)有太多的參數(shù),參數(shù)個(gè)數(shù)盡量控制在5 個(gè)以內(nèi)。如果參數(shù)太多,在使用時(shí)容易將參數(shù)類型或順序搞錯(cuò)。 178。 178。 【建議612】盡量不要使用類型和數(shù)目不確定的參數(shù)。C標(biāo)準(zhǔn)庫函數(shù)printf是采用不確定參數(shù)的典型代表,其原型為:int printf(const chat *format[, argument]…)。這種風(fēng)格的函數(shù)在編譯時(shí)喪失了嚴(yán)格的類型安全檢查。 返回值的規(guī)則l l 【規(guī)則621】不要省略返回值的類型。C語言中,凡不加類型說明的函數(shù),一律自動(dòng)按整型處理。這樣做不會(huì)有什么好處,卻容易被誤解為void類型。C++語言有很嚴(yán)格的類型安全檢查,不允許上述情況發(fā)生。由于C++程序可以調(diào)用C函數(shù),為了避免混亂,規(guī)定任何C++/ C函數(shù)都必須有類型。如果函數(shù)沒有返回值,那么應(yīng)聲明為void類型。 l l 【規(guī)則622】函數(shù)名字與返回值類型在語義上不可沖突。違反這條規(guī)則的典型代表是C標(biāo)準(zhǔn)庫函數(shù) getchar。例如:char c。c = getchar()。if (c == EOF)…按照getchar 名字的意思,將變量c聲明為char類型是很自然的事情。但不幸的是getchar的確不是char類型,而是int類型,其原型如下: int getchar(void)。由于c是char 類型,取值范圍是[128,127] ,如果宏 EOF的值在char 的取值范圍之外,那么if語句將總是失敗,這種 “危險(xiǎn)”人們一般哪里料得到!導(dǎo)致本例錯(cuò)誤的責(zé)任并不在用戶,是函數(shù)getchar誤導(dǎo)了使用者。 l l 【規(guī)則623】不要將正常值和錯(cuò)誤標(biāo)志混在一起返回。正常值用輸出參數(shù)獲得,而錯(cuò)誤標(biāo)志用return語句返回?;仡櫳侠?,C標(biāo)準(zhǔn)庫函數(shù)的設(shè)計(jì)者為什么要將 getchar聲明為令人迷糊的int類型呢?他會(huì)那么傻嗎?在正常情況下,getchar的確返回單個(gè)字符。但如果getchar碰到文件結(jié)束標(biāo)志或發(fā)生讀錯(cuò)誤,它必須返回一個(gè)標(biāo)志EOF。為了區(qū)別于正常的字符,只好將EOF 定義為負(fù)數(shù)(通常為負(fù)1)。因此函數(shù)getchar就成了int 類型。我們?cè)趯?shí)際工作中,經(jīng)常會(huì)碰到上述令人為難的問題。為了避免出現(xiàn)誤解,我們應(yīng)該將正常值和錯(cuò)誤標(biāo)志分開。即:正常值用輸出參數(shù)獲得,而錯(cuò)誤標(biāo)志用return語句返回。函數(shù)getchar 可以改寫成BOOL GetChar(char *c)。雖然gechar 比GetChar 靈活,例如 putchar(getchar())。 但是如果getchar用錯(cuò)了,它的靈活性又有什么用呢? 178。 178。 【建議621】有時(shí)候函數(shù)原本不需要返回值,但為了增加靈活性如支持鏈?zhǔn)奖磉_(dá),可以附加返回值。例如字符串拷貝函數(shù)strcpy的原型:char *strcpy(char *strDest,const char *strSrc)。strcpy函數(shù)將strSrc拷貝至輸出參數(shù)strDest中,同時(shí)函數(shù)的返回值又是 strDest。這樣做并非多此一舉,可以獲得如下靈活性: char str[20]。 int length = strlen( strcpy(str, “Hello World”) )。 178。 178。 【建議622】如果函數(shù)的返回值是一個(gè)對(duì)象,有些場(chǎng)合用 “引用傳遞”替換“值傳遞” 可以提高效率。而有些場(chǎng)合只能用“值傳遞”而不能用“ 引用傳遞” ,否則會(huì)出錯(cuò)。例如:class String{… // 賦值函數(shù) String amp。 operate=(const String amp。other)。 // 相加函數(shù),如果沒有friend修飾則只許有一個(gè)右側(cè)參數(shù)friend String operate+( const String amp。s1, const String amp。s2)。 private: char *m_data。 } String的賦值函數(shù)operate = 的實(shí)現(xiàn)如下:String amp。 String::operate=(const String amp。other){ if (this == amp。other) return *this。 delete m_data。 m_data = new char[strlen()+1]。 strcpy(m_data, )。 return *this。 // 返回的是 *this的引用,無需拷貝過程} 對(duì)于賦值函數(shù),應(yīng)當(dāng)用“引用傳遞 ”的方式返回String對(duì)象。如果用“值傳遞” 的方式,雖然功能仍然正確,但由于return 語句要把 *this拷貝到保存返回值的外部存儲(chǔ)單元之中,增加了不必要的開銷,降低了賦值函數(shù)的效率。例如: String a,b,c。 … a = b。 // 如果用“值傳遞”,將產(chǎn)生一次 *this 拷貝 a = b = c。 // 如果用“ 值傳遞”,將產(chǎn)生兩次 *this 拷貝 String的相加函數(shù)operate + 的實(shí)現(xiàn)如下:String operate+(const String amp。s1, const String amp。s2) { String temp。 delete 。 // ‘\0’的字符串 = new char[strlen() + strlen() +1]。 strcpy(, )。 strcat(, )。 return temp。 } 對(duì)于相加函數(shù),應(yīng)當(dāng)用“值傳遞”的方式返回String對(duì)象。如果改用“引用傳遞” ,那么函數(shù)返回值是一個(gè)指向局部對(duì)象temp的“引用” 。由于temp在函數(shù)結(jié)束時(shí)被自動(dòng)銷毀,將導(dǎo)致返回的“引用” 無效。例如: c = a + b。 此時(shí) a + b 并不返回期望值,c什么也得不到,流下了隱患。 函數(shù)內(nèi)部實(shí)現(xiàn)的規(guī)則不同功能的函數(shù)其內(nèi)部實(shí)現(xiàn)各不相同,看起來似乎無法就“內(nèi)部實(shí)現(xiàn)” 達(dá)成一致的觀點(diǎn)。但根據(jù)經(jīng)驗(yàn),我們可以在函數(shù)體的“ 入口處” 和“出口處”從嚴(yán)把關(guān),從而提高函數(shù)的質(zhì)量。 l l 【規(guī)則631 】在函數(shù)體的“入口處”,對(duì)參數(shù)的有效性進(jìn)行檢查。很多程序錯(cuò)誤是由非法參數(shù)引起的,我們應(yīng)該充分理解并正確使用“斷言” (assert)來防止此類錯(cuò)誤。 節(jié)“ 使用斷言 ”。 l l 【規(guī)則632】在函數(shù)體的 “出口處”,對(duì)return語句的正確性和效率進(jìn)行檢查。 如果函數(shù)有返回值,那么函數(shù)的“出口處” 是return 語句。我們不要輕視r(shí)eturn語句。如果return語句寫得不好,函數(shù)要么出錯(cuò),要么效率低下。注意事項(xiàng)如下:(1 )return語句不可返回指向“棧內(nèi)存”的“ 指針”或者“引用” ,因?yàn)樵搩?nèi)存在函數(shù)體結(jié)束時(shí)被自動(dòng)銷毀。例如 char * Func(void) { char str[] = “hello
點(diǎn)擊復(fù)制文檔內(nèi)容
教學(xué)教案相關(guān)推薦
文庫吧 www.dybbs8.com
備案圖鄂ICP備17016276號(hào)-1