//---------------------------15/03/29----------------------------

//#9    绝不在构造和析构过程中调头virtual函数

{

/*

1:在构造时调用virtual函数有两个结果

1>如果基类实现了这个函数,就调用基类的函数。

2>基类没有实现这个函数,链接时报错。

原因:

1>基类的构造函数是早于
派生类的构造函数调用的,所以如果virtual函数使用派生类版本的

话,很可能用到未初始化的派生类的成员变量。c++为了不让你走这条危险的路,就会只调用基类的版本

2>根本原因:在调用基类构造函数时,对象类型是base class,所以会调用基类版本。

所以不要在构造函数中调用任何virtual函数。

2:在析构函数中调用vitual函数:

由于派生类的析构函数是先于基类调用的,所以轮到基类的构造函数时,派生类的成员变量依旧呈现

未定义状态。所以c++视它们不存在,在调用基类析构函数时,对象称为一个base class对象。

3:为了在派生类对象创建时,基类中有适当版本的显示信息调用,一个解决办法是由派生类传入一个消息,

再调用non_virtual版本来显示。

*/

}

//#10   令 operator=
返回一个reference to *this

{

/*

关于赋值,c++中可以写成连锁形式:

int x,y,z;

x = y = z = 15;

为了实现这种连锁赋值,赋值操作符必须返回一个reference指向操作符的左侧实参。

*/

class Widget

{

public:

Widget&operator=(const Widget& rhs)

{

...

return *this;

}

};

}

//#11   在operator=中处理自我赋值

{

//看下面的函数

Widget&

Widget::operator=(const Widget& rhs)

{

delete pb;

pb =new Bitmap(*rhs.pb);

return *this;

}

//这样如果是自我赋值,那就先delete了pb,最后pb就指向一个已经删除的对象

//如果让operator=具备异常安全性
往往自动获得自我赋值安全。

Widget& Widget::operator=(const Widget& rhs)

{

Bitmap* pOrig = pb;

pb =new Bitmap(*rhs.pb);

delete pOrig;

return *this;

}

//这么做会有效率问题:如果是自我赋值,那就多做了一次new以及delete;但是考虑到自我赋值的几率

//并不建议在开头加上if判断来判断是否是自己。而且用了if语句,效率会明显下降

//还有种方法是使用swap保证异常安全性

Widget& Widget::operator=(const Widget& rhs)

{

Widget temp(rhs);

swap(temp);

return *this;

}

}

//#12   复制对象时勿忘其每一个成分

{

/*

1:当你自己实现operator=操作时,如果你忘记了一个成员变量的复制,编译器不会警告你

2:当你写自己的operator=或者copy构造函数时应该记得:

1>复制所有的自己的成员变量

2>调用所有base classes内的适当的copying函数。

3:如果发现copy构造函数和copy assignment操作符有相近的代码,消除重复代码的做法是

建立一个init成员函数,供两者调用。(但是考虑到前面的条目,构造函数直接初始化效率会很高,所以

如果相近的代码只是赋值的话,还是多动手的好)

*/

PriorityCustomer::PriorityCustomer(const PriorityCustomer& rhs)

:Customer(rhs), priority(rhs.priority)

{

...

}

PriorityCustomer&

PriorityCustomer::operator=(const PriorityCustomer& rhs)

{

...;

Customer::operator=(rhs);

prioriy = rhs.priority;

return *this;

}

}

effective c++ 笔记 (9-12)的更多相关文章

  1. [Effective JavaScript 笔记] 第12条:理解变量声明提升

    js支持词法作用域,即除了极少的例外,对变量的引用会被绑定到声明变量最近的作用域中. js不支持块级作用域,即变量定义的作用域并不是离其最近的封闭语句或代码块,而是包含它们的函数. 不了解这个会产生一 ...

  2. [Effective JavaScript 笔记]第3章:使用函数--个人总结

    前言 这一章把平时会用到,但不会深究的知识点,分开细化地讲解了.里面很多内容在高3等基础内容里,也有很多讲到.但由于本身书籍的篇幅较大,很容易忽视对应的小知识点.这章里的许多小提示都很有帮助,特别是在 ...

  3. Effective Java笔记一 创建和销毁对象

    Effective Java笔记一 创建和销毁对象 第1条 考虑用静态工厂方法代替构造器 第2条 遇到多个构造器参数时要考虑用构建器 第3条 用私有构造器或者枚举类型强化Singleton属性 第4条 ...

  4. [Effective JavaScript 笔记] 第4条:原始类型优于封闭对象

    js有5种原始值类型:布尔值.数字.字符串.null和undefined. 用typeof检测一下: typeof true; //"boolean" typeof 2; //&q ...

  5. [Effective JavaScript 笔记] 第5条:避免对混合类型使用==运算符

    “1.0e0”=={valueOf:function(){return true;}} 是值是多少? 这两个完全不同的值使用==运算符是相等的.为什么呢?请看<[Effective JavaSc ...

  6. [Effective JavaScript 笔记]第27条:使用闭包而不是字符串来封装代码

    函数是一种将代码作为数据结构存储的便利方式,代码之后可以被执行.这使得富有表现力的高阶函数抽象如map和forEach成为可能.它也是js异步I/O方法的核心.与此同时,也可以将代码表示为字符串的形式 ...

  7. [Effective JavaScript 笔记]第28条:不要信赖函数对象的toString方法

    js函数有一个非凡的特性,即将其源代码重现为字符串的能力. (function(x){ return x+1 }).toString();//"function (x){ return x+ ...

  8. java effective 读书笔记

    java effective 读书笔记 []创建和销毁对象 静态工厂方法 就是“封装了底层 暴露出一个访问接口 ” 门面模式 多参数时 用构建器,就是用个内部类 再让内部类提供构造好的对象 枚举 si ...

  9. Android菜鸟的成长笔记(12)——Handler、Loop、MessageQueue

    原文:[置顶] Android菜鸟的成长笔记(12)——Handler.Loop.MessageQueue 当一个程序第一次启动时,Android会启动一条主线程(Main Thread),主线程主要 ...

  10. Django商城项目笔记No.12用户部分-QQ登录2获取QQ用户openid

    Django商城项目笔记No.12用户部分-QQ登录2获取QQ用户openid 上一步获取QQ登录网址之后,测试登录之后本该跳转到这个界面 但是报错了: 新建oauth_callback.html & ...

随机推荐

  1. c#List数组移除元素

    ; i >= ; i--) //移除已经订阅的患者 { if (AllPatientsEntities[i].姓名 == item.患者姓名) AllPatientsEntities.Remov ...

  2. Jenkins自动构建的几种方式

    1.远程URL构建 在任务配置处的构建触发器中选择远程触发,例如,在下图框中输入abc,则只需要在网页上输入地址:Jenkins_URL/job/工程名/build?token=abc 2.利用cur ...

  3. innodb_fast_shutdown的内幕

    Innodb_fast_shutdown告诉innodb在它关闭的时候该做什么工作.有三个值可以选择:1.  0表示在innodb关闭的时候,需要purge all, merge insert buf ...

  4. Netty入门(七)使用SSL/TLS加密Netty程序

    为了支持 SSL/TLS,Java 提供了 javax.net.ssl API 的类 SslContext 和 SslEngine 使它相对简单的实现解密和加密.Netty 利用该 API 实现了 C ...

  5. js 判断元素是否在列表中

    /** * 使用循环的方式判断一个元素是否存在于一个数组中 * @param {Object} arr 数组 * @param {Object} value 元素值 */ function isInA ...

  6. 关于Netty Pipeline中Handler的执行顺序问题

    原文地址:http://blog.csdn.net/wgyvip/article/details/25637651 最近在学习Netty框架,根据官网的教程学着做了几个小测试,都成功了,后面开始试着写 ...

  7. 离线安装Cloudera Manager 5和CDH5(最新版5.9.3) 完全教程(一)环境说明

    关于CDH和Cloudera Manager CDH (Cloudera's Distribution, including Apache Hadoop),是Hadoop众多分支中的一种,由Cloud ...

  8. 服务器 三 MQTT服务器手机开发

    目的: 实现手机4G网络控制单片机,需要搭建服务器,手机或者各种控制端远程控制. 本教程 1  MQTT服务器硬件模块 2 MQTT服务器电脑搭建 2.1自己搭建 2.2租阿里云服务器 2 MQTT服 ...

  9. 【转】 python中 * 的用法

    转自:https://www.cnblogs.com/jony7/p/8035376.html 1.表示乘号 2.表示倍数,例如: def T(msg,time=1):    print((msg+' ...

  10. js_script

    使用 self.crawl 的 js_script 参数,在页面上执行一段脚本,实现[点击加载更多]的效果: def on_start(self): self.crawl('http://movie. ...