C++ 11:delete关键词和一条《Effective C++》的过时条款

在Scott Meyers的名著《Effective C++》中的条款5(了解C++默默编写并调用了哪些函数)和条款6(若不想使用编译器自动生成的函数,就应该明确拒绝)中提到以下几点:
以一个简单的类为例:

class base{
public:
};

在没有定义任何构造函数的情况下
1、编译器会自动生成default构造函数
2、编译器会自动生成copy构造函数
3、编译器会自动重载copy assignment操作符
4、编译器会自动生成析构函数

也就是自动生成了以下的代码:

class base{
public:
    //default构造函数
    base() {}
    //拷贝构造函数
    base(const base &rhs){}
    //析构函数
    ~base(){}
    //重载‘=’运算符
    base& operator=(const base& rhs){}
};

有的时候我们并不想使用编译器自动生成的函数,于是在《Effective C++》条款6中,采用了以下的方式杜绝编译器自动生成的函数。

class base{
public:
    ...
private:
    //如果我们要拒绝重载‘=’运算符,就把它设置为私有
    base& operator=(const base& rhs){}
};

但是在C++11中,我们有了更好的杜绝编译器自动生成的函数的方式:delete

class base{
public:
    ...
    //如果我们要拒绝重载‘=’运算符的默认函数,加上=delete即可
    base& operator=(const base& rhs)=delete;
};

int main(){
    base ba;
    base bb;
    ba = bb; //会出错,operator=重载已经被delete
}

被delete掉的成员函数不但无法调用,而且也不能被子类继承和覆盖。

猜你喜欢

转载自blog.csdn.net/thinkerleo1997/article/details/78619883
今日推荐