一、使用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)用開(kāi)銷(xiā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)潔和清晰易懂。
五、使用缺省參數(shù)
在C++中函數(shù)可以使用缺省參數(shù),例如:
void PutHzxy(char *str,int x=-1, int y=-1)
{
if(x==-1)
x=wherex();
if(y==-1)
x=wherex();
moveto(x,y);
PutHx(str);
}
可以有三種方式調(diào)用函數(shù)PutHzxy(),例如:
PutHzxy("C++語(yǔ)言");//使用缺省參數(shù)在當(dāng)前位置輸出
PutHzxy("C++語(yǔ)言",10,10);//沒(méi)有使用缺省參數(shù)
PutHzxy("C++語(yǔ)言",10);//對(duì)y使用缺省參數(shù),指定x的位置
通常的情況下,一個(gè)函數(shù)應(yīng)該具有盡可能大的靈活性。使用缺省參數(shù)為程序員處理更大的復(fù)雜性和靈活性問(wèn)題提供了有效的方法,所以在C++的代碼中都大量地使用了缺省參數(shù)。
需要說(shuō)明的是,所有的缺省參數(shù)必須出現(xiàn)在不缺省參數(shù)的右邊。亦即,一旦開(kāi)始定義缺省參數(shù),就不可再說(shuō)明非缺省的參數(shù)。
例如:
void PutHzxy(char*str,int x=-1,int y=-1)//正確
void PutHzxy(int x=-1,int y=-1,char*str)//錯(cuò)誤
六、使用STL
STL(Standard Template Library,標(biāo)準(zhǔn)模板庫(kù)), STL的代碼從廣義上講分為三類:algorithm(算法)、container(容器)和iterator(迭代器),并包括一些工具類如auto_ptr。幾乎所有的代碼都采用了模板類和模版函數(shù)的方式,這相比于傳統(tǒng)的由函數(shù)和類組成的庫(kù)來(lái)說(shuō)提供了更好的代碼重用機(jī)會(huì)。
#include<vector>// 包含相關(guān)的頭文件/
typedef std::vector<int> intvector;//使用typedef 使代碼看起來(lái)更簡(jiǎn)潔
int main()
{
intvector vi;
for(int i=0;i<10,i++)
vi.push_back(i);//使用push_back添加元素
for(int i=0;i<vi.size();i++)
std::cout<<vi[i]<<" ";//[]操作符被重載,使得我們可以像訪問(wèn)數(shù)組一樣訪問(wèn)vector中的元素
}
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |