复制构造函数是一种特殊的构造函数,具有单个形参,该形参常用const修饰是对该类类型的引用。当定义一个新对象并用同一类型的对象对他进行初始化时,将显示使用复制构造函数。当将该类型的对象传递给函数或从函数返回该类型的对象时,将隐式使用复制构造函数。今天在看《C++Primer》时,书中对复制构造函数这样解释。
怎么理解呢?复制构造函数具有单个的形参,而且该形参,是对本类类型对象的引用。复制构造函数可以由编译器隐式调用。一般用于:
1. 根据另一个同类型的对象显式或者隐式初始化一个对象。
2. 复制一个对象,将它作为实参传给一个参数。
3. 从函数返回时复制一个对象。
4. 初始化顺序容器中的元素。
5. 根据元素初始化列表初始化数组元素。
根据这五点,我们来理解一下复制构造函数。
一般情况下,我们没有显式定义复制构造函数时,编译器会为我们指定复制构造函数,而且基本不太会出错。
1.根据另一个同类型的对象显式或者隐式初始化一个对象。
2. 复制一个对象,将它作为实参传给一个参数。
class Sales_item3
{
public:
string getIsbn() const{return isbn;}
//公有成员
//普通构造函数
Sales_item3():units_sold(0),revenue(0.0)
{
cout << "调用默认构造函数"<<endl;
}
Sales_item3(const string &book)
:isbn(book),
units_sold(0),
revenue(0.0)
{cout<<"调用有参数的构造函数"<<endl;}
private:
string isbn;
unsigned units_sold;
double revenue;
};
int test3()
{
Sales_item3 a;//调用默认构造函数,第一个
Sales_item3 b("0-201-78345-X");//调用有参构造函数,第二个
Sales_item3 c(b);
cout << c.getIsbn() <<endl;
return 0;
}
Sales_item3 c(b);我们直接用b对象初始化c对象
我再写一个复制构造函数,执行同样的操作,直接用b对象初始化c对象
//复制构造函数,参数为类的引用,一个对象的数据成员赋给另外一个对象
Sales_item3(const Sales_item3 &orig)
:isbn(orig.isbn),
units_sold(orig.units_sold),
revenue(orig.revenue)
{
cout<<"复制构造函数被调用" <<endl;
}
或者直接a=b,也可以达到同样的效果。
3.从函数返回时复制一个对象。
增加一个函数foo
Sales_item3 foo(Sales_item3 item)
{
Sales_item3 temp;
temp = item;
return temp;
}
4. 初始化顺序容器中的元素。
增加代码:
cout<<endl<<"试一下vector容器:"<<endl;
vector<Sales_item3> svec(5);
执行结果:
5. 根据元素初始化列表初始化数组元素。
增加代码:
cout<<"试一下数组: " <<endl;
Sales_item3 primer_ends[] = {
string("0-201-16478-6"),
string("0-201-16478-7"),
string("0-201-16478-8"),
Sales_item3(),
};
输出为:
我们可以看到调用对应的构造函数的结果。