effective c++ 笔记 (30-31)

//---------------------------15/04/17----------------------------

//#30   透彻了解inlineing的里里外外

{

/*

1:inline函数通常可以免除函数调用的成本,而且编译器会对它执行语境相关最优化。

2:使用inline函数很有可能增加你的目标码的大小。因为对每个函数的调用都使用函数本体来替换,如果函数

本体很大的话代码膨胀是肯定的。但是如果inline函数的本体很小,那么将产生出小的码。

3:inline只是对编译器的一个申请,不是命令。

4:定义在class定义式内的成员函数默认使用inline。

5:inline函数通常一定被置于头文件,因为一般情况下,编译器在编译期间必须要知道函数本体才能替换成功。

6:编译器拒绝一些复杂的inline函数,比如递归(书上说循环也不行,但是记得看到过很多人都说循环是可以inline

的),编译器拒绝virtual函数,因为这些函数到了运行期才确定调用哪一个函数。

7:编译器不对“通过函数指针而进行的调用”实施inlining。

8:不要对构造和析构函数指定inline。

9:inline函数使得用到这个函数的程序,在函数改动后必须重新编译。

10:总结:一开始别使用inline,当遇到造成效率影响的20%的代码时,可以找机会将它inline。

*/

}

//#31   将文件间的编译依存关系将至最低

{

/*

1:考虑三个设计策略:

1>如果使用object references或 object pointers可以完成任务,就不要使用objects。

如果只需要point或references,编译器就不需要知道object的大小,也就不需要知道它的

具体定义,当使用这个object pointer时,可以包含一个声明式就好。

2>如果可能,尽量以class声明式替换class定义式。

这样除非到了真正调用时,就可以不管class的定义。也就去除了编译依存。

3>为声明式和定义式提供不同的头文件。

为了实现上面的准则,提供声明式的头文件,就可以让客户选择只包含声明。

2:实现声明和实现分离的办法有两个:

1>在类中包含一个需要具体操作的指针对象,在需要功能的时候通过指针对象的功能:         */

#include "PersonImpl.h"

#include "People.h"

Person::Person(const std::string& name,const Date& birthday,
const Address& addr)

: pImpl(new PersonImpl(name, birthday, addr)){}

std::string Person::name()const

{

return pImpl->name();

}

/*      其实这就是设计模式中桥接模式的思想。分离接口与实现的技术。

2>通过接口一个接口类,这个类没有成员变量,只有一个virtual析构函数和一组pure virtual。

客户可以使用这个接口类,必须只能使用这个类的指针,因为内含pure virtual函数的class是

无法实例化的。然后使用一个工厂类来获得具体对象。

其实这就是设计模式中的工厂方法模式。

3:记得一点:

头文件应该以“完全且仅有声明式”的形式存在。

*/

}

时间: 2024-11-10 17:38:20

effective c++ 笔记 (30-31)的相关文章

[Effective JavaScript 笔记]第31条:使用Object.getPrototypeOf函数而不要使用__proto__属性

ES5引入Object.getPrototypeOf函数作为获取对象原型的标准API,但由于之前的很多js引擎使用了一个特殊的__proto__属性来达到相同的目的.但有些浏览器并不支持这个__proto__属性,所以并不是完全兼容的.例如对于拥有null原型的对象,不同的环境结果就不同了. var empty=Object.create(null); '__proto__' in empty;//一些环境会返回false,另一些会返回true 这就导致结果的不一致,从而影响到依赖这个判断的相关

Effective C++笔记05:实现

条款26:尽可能延后变量定义式的出现时间 博客地址:http://blog.csdn.net/cv_ronny 转载请注明出处! 有些对象,你可能过早的定义它,而在代码执行的过程中发生了导常,造成了开始定义的对象并没有被使用,而付出了构造成本来析构成本. 所以我们应该在定义对象时,尽可能的延后,甚至直到非得使用该变量前一刻为止,应该尝试延后这份定义直到能够给它初值实参为止. 这样做的好处是:不仅可以避免构造(析构)非必要对象,还可以避免无意义的default构造行为. 遇到循环怎么办?此时往往我

[原创]java WEB学习笔记30:Cookie Demo 之显示最近浏览的记录

本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 ---------------------------------

《生命的幻象》作者的动画笔记30条(全)

<生命的幻象>作者Ollie Johnston的动画笔记30条(全) (Ollie Johnston 和 Frank Thomas 合著了著名动画书籍<Illusion of Life>,译者注) 作者:John Lasseter, Pixar公司 编译:Luonaldo(又见到他了) <ignore_js_op> “当我在Disney公司作一名动画师的时候,我有一份复印的列表,是来自于Disney最伟大的动画师之一,Ollie Johnston的一些简单的笔记,我把它

Effective C++笔记:构造/析构/赋值运算

条款05:了解C++默默编写并调用哪些函数 默认构造函数.拷贝构造函数.拷贝赋值函数.析构函数构成了一个类的脊梁,只有良好的处理这些函数的定义才能保证类的设计良好性. 当我们没有人为的定义上面的几个函数时,编译器会给我们构造默认的. 当成员变量里有const对象或引用类型时,编译器会不能合成默认的拷贝赋值函数:当一个基类把它的拷贝赋值函数定义为private时,它的派生类也不无生成默认的拷贝赋值函数,因为它无法完成基类成份的赋值. 条款06:若不想使用编译器自动生成的函数,就该明确拒绝 将拷贝构

[读书笔记]30岁前的每一天

30岁之后,我觉得梦想离我越来越近了.我从事自己热爱的工作,有许多时间陪伴家人和朋友.我找到了生命的另一半,因为他的存在,我有勇气面对生活的任何艰难困苦.我走向了财富自由的道路,不再为薪水收入的多少而烦恼. 财富自由,是实现梦想最重要的基础,财富自由意味着你有足够的时间去做你想做的事,不必再熬夜加班,不必再看老板的脸色."踏上财富自由之路"这一部分,讲述投资理财最基础的观念和技能,希望能帮助你作出改变. 梦想要好高骛远,行动要脚踏实地,这就是记事本存在的意义.很多人都用记事本,可是很多

Effective C++笔记06:继承与面向对象设计

关于OOP 博客地址:http://blog.csdn.net/cv_ronny 转载请注明出处! 1,继承可以是单一继承或多重继承,每一个继承连接可以是public.protected或private,也可以是virtual或non-virtual. 2,成员函数的各个选项:virtual或non-virtual或pure-virtual. 3,成员函数和其他语言特性的交互影响:缺省参数值与virtual函数有什么交互影响?继承如何影响C++的名称查找规则?设计选项有如些?如果class的行为

Effective c++(笔记)之继承关系与面向对象设计

1.公有继承(public inheritance) 意味着"是一种"(isa)的关系 解析:一定要深刻理解这句话的含义,不要认为这大家都知道,本来我也这样认为,当我看完这章后,就不这样认为了. 公有继承可以这样理解,如果令class D以public 的形式继承了class B ,那么可以这样认为,每一个类型为D的对象同时也可以认为是类型为B的对象,但反过来是不成立的,对象D是更特殊化更具体的的概念,而B是更一般化的概念,每一件事情只要能够施行于基类对象身上,就一定可以应用于派生类对

CSAPP 读书笔记 - 2.31练习题

根据等式(2-14) 假如w = 4 数值范围在-8 ~ 7之间 2^w = 16 x = 5, y = 4的情况下面 x + y = 9 >=2 ^(w-1)  属于第一种情况 sum = x + y = 9- 2^w  = –7 sum – x == y? -7 – 4 = – 11 属于第三种情况 负溢出 sum – x  = –7 - 4= –11 + 2^w = 5  = y? 明显是等于的 同样 sum- y = x ? -7 – 5 = –12 + 2^w = 4 = x? 所以溢

Effective C++笔记_条款25考虑写出一个不抛出异常的swap函数

1 // lib中的swap 2 namespace std { 3 template<typename T> 4 void swap (T& a, T& b) 5 { 6 T temp(a); 7 a = b; 8 b = temp; 9 } 10 } 11 12 // 缺点:需要赋值大量的数据,但是有的时候并不要复制如此多的内容 13 class WidgetImpl { 14 public: 15 //... 16 private: 17 int a, b, c; 18