指針使用時(shí)應(yīng)該注意的一些地方
1. 當(dāng)改變指針指向時(shí)要注意delete。
如果當(dāng)前是指向自由存儲器,則必須在給指針賦予新的地址前釋放內(nèi)存,否則以后將無法釋放該地址。
int* p = new int(10);
int a = 12;
//delete p;
p = &a;
如果不先delete p,開始分配給p的內(nèi)存就會一直被占用并且無法釋放了。
2. 一定要給包含指針數(shù)據(jù)的類提供復(fù)制構(gòu)造函數(shù)。
比如一個(gè)簡單的消息類:Massage,其中只包含一個(gè)char* msg的數(shù)據(jù)成員。
Massage msg1 ("This is a msg");
Massage msg2(msg1);
如上語句將使得msg2中的char*指向msg1的char*地址,任何對msg1的修改將影響到msg2,反之亦然。我們此時(shí)希望的是都得msg1的一個(gè)副本,而不是它的地址。因此我們需要給Massage類提供一個(gè)復(fù)制構(gòu)造函數(shù),大概可以像這個(gè)樣子:












另一種比較隱蔽的情況是,當(dāng)你把msg1當(dāng)成某函數(shù)的參數(shù)時(shí),系統(tǒng)需要調(diào)用復(fù)制構(gòu)造函數(shù)。假如有如下函數(shù):void showMasage(Massage aMsg):
我們?nèi)绻褂胹howMassge(msg1),該函數(shù)會正常工作,但是,在該函數(shù)返回之后,msg1將無法再使用。因?yàn)楫?dāng)msg1作為實(shí)參傳遞給showMassge之后,系統(tǒng)將自動(dòng)生成一個(gè)它的副本:aMsg。不過假如我們沒有提供復(fù)制構(gòu)造函數(shù),aMsg和msg1的char*將指向同一個(gè)地址,而aMsg將在showMassage返回時(shí)被銷毀,它指向的那塊內(nèi)存也會同時(shí)被釋放,不幸的是,msg1也"碰巧"指向了這個(gè)被釋放的地址,以后想使用msg1將會導(dǎo)致不可預(yù)測的結(jié)果。
因此,只要類的數(shù)據(jù)成員中包含指針,我們就應(yīng)該為其提供復(fù)制構(gòu)造函數(shù)。
3. const char * p, char * const p, char const * p
這里不是想討論常量指針和指針常量,而是想說下char const * p。這里,const修飾的并不是p,而是char,這條語句相當(dāng)于const char *p。不過從寫法上很容易誤解,所以最好不要采用這種寫法。
posted on 2008-06-08 14:07 54sun 閱讀(617) 評論(0) 編輯 收藏 引用 所屬分類: C++