C++類中的特殊成員函數-------復制構造函數
阿新 • • 發佈:2017-07-17
code amp 默認 tdi blog 復制構造函數 stat int ios
在C++中存在一個特殊函數,他就是復制構造函數,假如我們有類A,如果有A a;A b=a; 在這種情況下利用A類變量a來給同是A類變量的b來賦值,這個時候類會使用復制構造函數,如果我們不顯式聲明復制構造函數,那麽類將會調用默認的復制構造函數。下面的代碼說明了這一情況,如果我們將類StringBad中的復制構造函數StringBad(StringBad &)去掉,那麽count最後輸出的結果會為復制(count為靜態變量用來記錄類StringBad的對象個數)。
main.cpp
#include <iostream> #include"StringBad.h" usingnamespace std; int main() { StringBad * src=new StringBad("src"); StringBad srb("srb"); StringBad srd=srb; delete src; return 0; }
StringBad.h
#include<iostream> #include<stdio.h> using namespace std; class StringBad{ public: static int count; char * name; StringBad(char * name); StringBad(StringBad &); ~StringBad(); };
StringBad.cpp
#include"string.h" #include<iostream> #include<stdio.h> #include"StringBad.h" using namespace std; int StringBad::count=0; StringBad::StringBad(char * name){ this->name=new char(strlen(name)+1); strcpy(this->name,name); count++; cout<<"創建新對象"<<(this->name)<<"後,還有"<<count<<"個對象"<<endl; } StringBad::~StringBad(){ count--; cout<<"析構"<<(this->name)<<"之後,還有"<<count<<"個對象"<<endl; } StringBad::StringBad(StringBad & s) { count++; this->name=new char(strlen(s.name)+1); strcpy(this->name,s.name); cout<<"調用復制函數後,還有"<<count<<"個對象"<<endl; }
C++類中的特殊成員函數-------復制構造函數