再談拷貝構(gòu)造函數(shù)(Copy Constructor Function)
前段時(shí)間有人發(fā)表了關(guān)于拷貝構(gòu)造函數(shù)的問題,我覺得對(duì)于拷貝構(gòu)造函數(shù)要掌握四點(diǎn)(以下以CCF代稱拷貝構(gòu)造函數(shù))
第一:默認(rèn)CCF提供對(duì)象之間的位拷貝(Bitwise Copy),對(duì)于指針類成員只會(huì)將至指針值復(fù)制
第二:CCF在對(duì)象初始化時(shí)才發(fā)揮作用,而在對(duì)象賦值的時(shí)候不起作用
第三:在沒有顯示聲明成員CCF的情況下,編譯器會(huì)自動(dòng)生成默認(rèn)CCF,如果顯示聲明了顯示CCF,則編譯器不會(huì)生成默認(rèn)CCF,至少是不會(huì)調(diào)用
第四:與構(gòu)造函數(shù)不同,CCF并不會(huì)遞歸的調(diào)用基類的CCF,子類與基類的CCF是覆蓋關(guān)系,與就是說子類會(huì)尋找與自己關(guān)系最近的CCF調(diào)用,如果子類有CCF則僅調(diào)用子類CCF,如果子類沒有向上尋找,調(diào)用第一個(gè)找到的CCF
第五:CCF的聲明及定義如下:
classname(classname const&obj)2


{3
m1=obj.m1;4
m2=obj.m2;5


.6
Lp1=new type[size];7
memcpy_s(Lp1,size,obj.Lp1);8
Lp2=new type[size];9
memcpy_s(Lp2,size,obj.Lp2);10


.11
}而具體到第二點(diǎn),CCF在以下情況下也會(huì)被調(diào)用:
1) 一個(gè)對(duì)象以值傳遞的方式傳入函數(shù)體;
2) 一個(gè)對(duì)象以值傳遞的方式從函數(shù)返回;
3) 一個(gè)對(duì)象需要通過另外一個(gè)對(duì)象進(jìn)行初始化;
除此之外,對(duì)于對(duì)象復(fù)制是我們經(jīng)常會(huì)忽略或混淆的一點(diǎn),在對(duì)賦值的時(shí)候不會(huì)調(diào)用CCF,需要自己去重載“=”
注意:對(duì)于包含動(dòng)態(tài)分配成員的類提供拷貝構(gòu)造函數(shù)和重載"="賦值操作符號(hào)是一個(gè)良好的編程習(xí)慣。
愿意如下:
動(dòng)態(tài)成員如指針,在默認(rèn)CCF和默認(rèn)“=”操作符下僅僅執(zhí)行位拷貝,而指針?biāo)赶虻膬?nèi)存區(qū)域不會(huì)被拷貝,造成內(nèi)存錯(cuò)誤操作
以下例程可用來實(shí)驗(yàn):
#pragma once
#include "tchar.h"
class mycls

{
public:
mycls(){};
mycls(mycls const & obj)
{
//delete[] mp_str1;
mp_str1=new TCHAR[100];
_tcscpy_s(mp_str1,100,obj.mp_str1);
}
char a[100000];
TCHAR b[1000];
//~mycls(void);
int m_q;
TCHAR* mp_str1;
char* mp_str2;
};
class mycls2:public mycls

{
public:
mycls2():bb(10)
{};
mycls2(mycls2 const&obj)
{
bb=obj.bb;
}
int bb;
};
posted on 2008-12-05 23:19 pear_li 閱讀(3969) 評(píng)論(12) 編輯 收藏 引用 所屬分類: C++
