0.概述:
编译器可以暗自为class创建默认构造函数、拷贝构造函数和拷贝赋值操作符,以及析构函数。
上述所有函数都是public且inline的,因此如果写
class Empty();
就相当于写了
class Empty {
public:
Empty() { ... } // 默认构造
Empty(const Empty& rhs) { ... } // 拷贝构造
~Empty() { ... } // 析构函数
Empty& operator=(const Empty& rhs) { ... } // 拷贝赋值操作符
};
当这些函数需要被调用时,才会被编译器创造出来,如下:
Empty e1; // 默认构造;
// 析构
Empty e2(e1); // 拷贝构造
e2 = e1; // 拷贝赋值
1.构造函数和析构函数
default构造函数和析构函数主要是给编译器一个地方用来放置“藏身幕后”的代码,像是调用base classes和non-static成员变量的构造函数和析构函数。
注意,编译器产出的析构函数是个non-virtual(见条款7),除非这个class的base class自身声明有virtual析构函数(这种情况下这个函数的虚属性virtualness,主要来自base class)。
2.拷贝构造和拷贝赋值
将来源对象的每一个非静态成员变量拷贝到目标对象
3.实例讲解namedObject类
template<typename T>
class NamedObject {
public:
NamedObject(const char *name, const T& value);
NamedObject(const std::string& name, const T& value);
...
private:
std::string nameValue;
T objectValue;
};
拷贝构造函数用法:
NamedObject<int> no1("Smallest Prime Number", 2);
NamedObject<int> no2(no1); // 调用copy constructor
编译器生成的copy构造函数必须以no1. nameValue和no1. objectValue为初值设定no2. nameValue和no2.objectValue。
- nameValue为string类型,标准string有拷贝构造函数。因此no2. nameValue的初始化方式是调用string的拷贝构造函数并以no1. nameValue为实参。
- NamedObject<int>::objectValue为int类型,属于内置类型。因此no2.objectValue会以拷贝no1. objectValue的每个bits完成初始化。