新增的默认成员函数
我们知道,默认成员函数就是我们不写编译器会生成一个默认的。
在C++11之前,默认成员函数有6个:
- 构造函数
- 析构函数
- 拷贝构造函数
- 拷贝赋值重载
- 取地址重载
- const 取地址重载
后两个不重要,因为一般从不需要我们自己实现。
C++11 新增了两个:移动构造函数和移动赋值运算符重载。
我们知道,在深拷贝的类中是需要它们的,而在浅拷贝的类中并不需要它们。
那么:
- 如果我们不自己实现,编译器默认生成的会干些什么事呢?
- 如果我们不自己实现,什么情况下编译器才会默认生成呢?
针对移动构造函数和移动赋值运算符重载有一些需要注意的点如下:
-
如果没有自己实现移动构造函数和移动赋值重载函数,并且你也均没有实现析构函数 、拷贝构造、拷贝赋值重载,那么编译器会自动生成默认移动构造和移动赋值重载函数。
-
默认生成的移动构造函数和移动赋值重载函数
- 对于内置类型成员会执行逐成员按字节拷贝(浅拷贝)
- 对于自定义类型成员,则需要看这个成员是否实现移动构造,如果实现了就调用移动构造,没有实现就调用拷贝构造。
-
如果自己实现了移动构造或者移动赋值,编译器不会自动提供拷贝构造和拷贝赋值。
强制生成默认函数的关键字default
如果我们类中实现了析构函数或者拷贝构造或者拷贝赋值重载,还想要编译器给我们生成默认的移动构造或移动重载,可以用关键字default,强制编译器为我们生成。
比如:
class Person
{
public:
Person(const char* name = "", int age = 0)
:_name(name)
, _age(age)
{}
//自己实现了拷贝构造,编译器就不会自动生成移动构造和移动重载了
Person(const Person& p)
:_name(p._name)
,_age(p._age)
{}
//强制编译器生成移动构造
Person(Person&& p) = default;
private:
zhh::string _name;
int _age;
};
禁止生成默认函数的关键字delete
- 如果能想要限制某些默认函数的生成,在C++98中,是该函数设置成private这样只要其他人想要调用就会报错。
- 在C++11中更简单,只需在该函数声明加上=delete即可,该语法指示编译器不生成对应函数的默认版本,称=delete修饰的函数为删除函数。
比如:禁止编译器自动生成默认的拷贝构造函数
class Person
{
public:
Person(const char* name = "", int age = 0)
:_name(name)
, _age(age)
{}
//禁止编译器生成拷贝构造
Person(const Person& p) = delete;
private:
zhh::string _name;
int _age;
};

1344

被折叠的 条评论
为什么被折叠?



