博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C++ 11:delete关键词和一条《Effective C++》的过时条款
阅读量:4205 次
发布时间:2019-05-26

本文共 836 字,大约阅读时间需要 2 分钟。

在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掉的成员函数不但无法调用,而且也不能被子类继承和覆盖。

转载地址:http://qxoli.baihongyu.com/

你可能感兴趣的文章
14丨性能测试场景:如何理解业务模型
查看>>
Prometheus exporter详解
查看>>
15丨性能测试场景:如何进行监控设计
查看>>
16丨案例:性能监控工具之Grafana-Prometheus-Exporters
查看>>
九度OJ 1085:求root(N, k) (迭代)
查看>>
九度OJ 1086:最小花费 (DP)
查看>>
九度OJ 1087:约数的个数 (数字特性)
查看>>
九度OJ 1088:剩下的树 (线段树)
查看>>
九度OJ 1089:数字反转 (数字反转)
查看>>
九度OJ 1090:路径打印 (树、DFS)
查看>>
九度OJ 1091:棋盘游戏 (DP、BFS、DFS、剪枝)
查看>>
九度OJ 1092:Fibonacci (递归)
查看>>
九度OJ 1093:WERTYU (翻译)
查看>>
九度OJ 1094:String Matching(字符串匹配) (计数)
查看>>
九度OJ 1095:2的幂次方 (递归)
查看>>
九度OJ 1471-1480(10/10)
查看>>
九度OJ 1481-1490(7/10)
查看>>
九度OJ 1491-1500(5/10)
查看>>
九度OJ 1501-1510(10/10)
查看>>
业务系统中,报表统计功能如何组织--统计分析模块参考
查看>>