一、使用new和delete進(jìn)行動(dòng)態(tài)內(nèi)存分配和釋放
運(yùn)算符new和delete是C++新增的運(yùn)算符,提供了存儲(chǔ)的動(dòng)態(tài)分配和釋放功能。它的作用相當(dāng)于C語(yǔ)言的函數(shù)malloc()和free(),但是性能更為優(yōu)越。使用new較之使用malloc()有以下的幾個(gè)優(yōu)點(diǎn):
(1)new自動(dòng)計(jì)算要分配類型的大小,不使用sizeof運(yùn)算符,比較省事,可以避免錯(cuò)誤。
(2)自動(dòng)地返回正確的指針類型,不用進(jìn)行強(qiáng)制指針類型轉(zhuǎn)換。
(3)可以用new對(duì)分配的對(duì)象進(jìn)行初始化。
使用例子:
(1)int* p;
p=new int[10]; //分配一個(gè)含有10個(gè)整數(shù)的整形數(shù)組
delete[] p; //刪除這個(gè)數(shù)組
(2)int* p;
p=new int (100);//動(dòng)態(tài)分配一個(gè)整數(shù)并初始化
二、使用inline內(nèi)連函數(shù)替代宏調(diào)用
對(duì)于頻繁使用的函數(shù),C語(yǔ)言建議使用宏調(diào)用代替函數(shù)調(diào)用以加快代碼執(zhí)行,減少調(diào)用開銷。但是宏調(diào)用有許多的弊端,可能引起不期望的副作用。例如宏:#define abs(a) ((a)<0?(-a):(a)), 當(dāng)使用abs(i++)時(shí),這個(gè)宏就會(huì)出錯(cuò)。
所以在C++中應(yīng)該使用inline內(nèi)連函數(shù)替代宏調(diào)用,這樣既可達(dá)到宏調(diào)用的目的,又避免了宏調(diào)用的弊端。
使用內(nèi)連函數(shù)只須把inline關(guān)鍵字放在函數(shù)返回類型的前面。例如:
inline int Add(int a,int b);//聲明Add()為內(nèi)連函數(shù)
這樣編譯器在遇到Add()函數(shù)時(shí),就不再進(jìn)行函數(shù)調(diào)用,而是直接嵌入函數(shù)代碼以加快程序的執(zhí)行。
三、使用函數(shù)重載
在C語(yǔ)言中,兩個(gè)函數(shù)的名稱不能相同,否則會(huì)導(dǎo)致編譯錯(cuò)誤。而在C++中,函數(shù)名相同而參數(shù)數(shù)據(jù)類型不同的兩個(gè)函數(shù)被解釋為重載。例如:
void PutHz(char* str);//在當(dāng)前位置輸出漢字
void PutHz(int x,int y,char * str);//在x,y處輸入數(shù)字
使用函數(shù)重載可以幫助程序員處理更多的復(fù)雜問(wèn)題,避免了使用諸如intabs()、fabs()、dabs()等繁雜的函數(shù)名稱;同時(shí)在大型程序中,使函數(shù)名易于管理和使用,而不必絞盡腦汁地去處理函數(shù)名。同時(shí)必須注意,參數(shù)數(shù)據(jù)類型相同,但是函數(shù)返回類型不同的兩個(gè)函數(shù)不能重載。
四、使用引用(reference)代替指針進(jìn)行參數(shù)傳遞
在C語(yǔ)言中,如果一個(gè)函數(shù)需要修改用作參數(shù)的變量值的時(shí)候 ,參數(shù)應(yīng)該聲明為指針類型。例如:
void Add(int *a)
{
*a++;
}
調(diào)用時(shí)則使用
Add(&x); //其中x為int或可以轉(zhuǎn)化為int的類型,如unsigned int, 但這時(shí)候編譯器通過(guò)回給出warning
對(duì)于復(fù)雜的程序,使用指針容易出錯(cuò),程序也難以讀懂。在C++中,對(duì)于上述情況 可以使用引用來(lái)代替指針,使程序更加清晰易懂。引用就是對(duì)變量取的一個(gè)別名,對(duì)引用進(jìn)行操作,這就相當(dāng)于對(duì)原有變量進(jìn)行操作。例如使用引用的函數(shù)定義為:
void Add(int& a)
{
a++;//a為一個(gè)整數(shù)的引用
}
調(diào)用時(shí)使用
Add(x); //其中x為int
這個(gè)函數(shù)與使用指針的上一個(gè)函數(shù)的功能是一樣的,然而代碼卻更為簡(jiǎn)潔和清晰易懂。
運(yùn)算符new和delete是C++新增的運(yùn)算符,提供了存儲(chǔ)的動(dòng)態(tài)分配和釋放功能。它的作用相當(dāng)于C語(yǔ)言的函數(shù)malloc()和free(),但是性能更為優(yōu)越。使用new較之使用malloc()有以下的幾個(gè)優(yōu)點(diǎn):
(1)new自動(dòng)計(jì)算要分配類型的大小,不使用sizeof運(yùn)算符,比較省事,可以避免錯(cuò)誤。
(2)自動(dòng)地返回正確的指針類型,不用進(jìn)行強(qiáng)制指針類型轉(zhuǎn)換。
(3)可以用new對(duì)分配的對(duì)象進(jìn)行初始化。
使用例子:
(1)int* p;
p=new int[10]; //分配一個(gè)含有10個(gè)整數(shù)的整形數(shù)組
delete[] p; //刪除這個(gè)數(shù)組
(2)int* p;
p=new int (100);//動(dòng)態(tài)分配一個(gè)整數(shù)并初始化
二、使用inline內(nèi)連函數(shù)替代宏調(diào)用
對(duì)于頻繁使用的函數(shù),C語(yǔ)言建議使用宏調(diào)用代替函數(shù)調(diào)用以加快代碼執(zhí)行,減少調(diào)用開銷。但是宏調(diào)用有許多的弊端,可能引起不期望的副作用。例如宏:#define abs(a) ((a)<0?(-a):(a)), 當(dāng)使用abs(i++)時(shí),這個(gè)宏就會(huì)出錯(cuò)。
所以在C++中應(yīng)該使用inline內(nèi)連函數(shù)替代宏調(diào)用,這樣既可達(dá)到宏調(diào)用的目的,又避免了宏調(diào)用的弊端。
使用內(nèi)連函數(shù)只須把inline關(guān)鍵字放在函數(shù)返回類型的前面。例如:
inline int Add(int a,int b);//聲明Add()為內(nèi)連函數(shù)
這樣編譯器在遇到Add()函數(shù)時(shí),就不再進(jìn)行函數(shù)調(diào)用,而是直接嵌入函數(shù)代碼以加快程序的執(zhí)行。
三、使用函數(shù)重載
在C語(yǔ)言中,兩個(gè)函數(shù)的名稱不能相同,否則會(huì)導(dǎo)致編譯錯(cuò)誤。而在C++中,函數(shù)名相同而參數(shù)數(shù)據(jù)類型不同的兩個(gè)函數(shù)被解釋為重載。例如:
void PutHz(char* str);//在當(dāng)前位置輸出漢字
void PutHz(int x,int y,char * str);//在x,y處輸入數(shù)字
使用函數(shù)重載可以幫助程序員處理更多的復(fù)雜問(wèn)題,避免了使用諸如intabs()、fabs()、dabs()等繁雜的函數(shù)名稱;同時(shí)在大型程序中,使函數(shù)名易于管理和使用,而不必絞盡腦汁地去處理函數(shù)名。同時(shí)必須注意,參數(shù)數(shù)據(jù)類型相同,但是函數(shù)返回類型不同的兩個(gè)函數(shù)不能重載。
四、使用引用(reference)代替指針進(jìn)行參數(shù)傳遞
在C語(yǔ)言中,如果一個(gè)函數(shù)需要修改用作參數(shù)的變量值的時(shí)候 ,參數(shù)應(yīng)該聲明為指針類型。例如:
void Add(int *a)
{
*a++;
}
調(diào)用時(shí)則使用
Add(&x); //其中x為int或可以轉(zhuǎn)化為int的類型,如unsigned int, 但這時(shí)候編譯器通過(guò)回給出warning
對(duì)于復(fù)雜的程序,使用指針容易出錯(cuò),程序也難以讀懂。在C++中,對(duì)于上述情況 可以使用引用來(lái)代替指針,使程序更加清晰易懂。引用就是對(duì)變量取的一個(gè)別名,對(duì)引用進(jìn)行操作,這就相當(dāng)于對(duì)原有變量進(jìn)行操作。例如使用引用的函數(shù)定義為:
void Add(int& a)
{
a++;//a為一個(gè)整數(shù)的引用
}
調(diào)用時(shí)使用
Add(x); //其中x為int
這個(gè)函數(shù)與使用指針的上一個(gè)函數(shù)的功能是一樣的,然而代碼卻更為簡(jiǎn)潔和清晰易懂。