Effective C++ 读书笔记(1-7)
作者 Scott Meyers 翻译作者 侯捷 C++ 神牛 台湾人
术语:
1.explicit
C++提供了关键字explicit,可以阻止不应该允许的经过转换构造函数进行的隐式转换的发生。声明为explicit的构造函数不能在隐式转换中使用。但他们仍然可以用来进行显示转换。
示例:
class Test1
{
public:
Test1(int n) { num = n; } //普通构造函数
private:
int num;
};
class Test2
{
public:
explicit Test2(int n) { num = n; } //explicit(显式)构造函数
private:
int num;
};
int main()
{
Test1 t1 = ; //隐式调用其构造函数, 成功
Test2 t2 = ; //编译错误,不能隐式调用其构造函数
Test2 t3(); //显式调用成功
return ;
}
2 undefined behavior
int *p=; //p其实是一个NULL指针
std::cout<<*p;//对一个NULL指针取值会导致不明确行为。
条款一:
封装 encapsulation、继承 inheritance、多态 polymorphism
在STL中,迭代器和函数对象都是在C指针之上塑造的,所以对STL的迭代器和函数对象而言,旧式的pass-by-value守则再次适用。
C++高效编程守则视状况而变化,取决于你适用C++的那一部分。 C、Object-Oriented C++、Template C++、STL
条款二:
scope 作用域
enum hock 一个属于枚举类型的数值可权充ints被适用。//权充 (暂且充当)
取一个const的地址是合法的,但取一个enum的地址不合法。
class GamePlayer
{
private:
enum {NumTurns=};
int scores[NumTurns];
.....
};
宏的不可思议:
#include<iostream> #define call(a,b) (a)>(b)?(a):(b)
int main()
{ int lv1=,rv1=;
int lv2=,rv2=;
int result1=call(++lv1,rv1); //lv1累加2次为7
int result2=call(++lv2,rv2+); //lv2累加1次为6
std::cout<<result1<<" "<<lv1<<std::endl;
std::cout<<result2<<" "<<lv2<<std::endl;
system("pause"); return ;
}
条款三:
1.STL中iterator的const用法:
std::vector<int> vec;
...
const std::vector<int>::iterator iter=vec.begin();//iter 的作用像个T* const
*iter=; //没问题,改变iter所指物
++iter; //错误! iter是const
std::vector<int>::const_iterator cIter=vec.begin(); //cIter的作用像个const *T
*cIter=; //错误! *cIter是const
++cIter; //没问题,改变cIter
2.const成员函数不可以更改对象内任何non-static成员变量。
3.利用C++的一个与const相关的摆动场:mutable(可变的)释放掉non-static成员变量的bitwise constness约束。
mutable bool lengthIsValid;
CTextBlock::length() const//这些成员变量可能总是会被更改,即使在const成员函数内。
{
lengthIsValid=false;
}
4.const_cast: 通常被用来将对象的常量性转除。也是唯一有此能力的C++-style转型操作符。
static_cast:用来强迫隐式转换(implicit conversions),如将non-const对象转为const对象,或者int转为double。
条款四:确定对象被使用前已先被初始化
1.构造函数最好使用成员初始化而不要在构造函数本体内使用赋值操作,初始值列列出的成员变量,其排序次序应该和他们在class类中的声明次序相同。
2.base classess 更早于其derived classes被初始化,而class的成员变量总是以其声明次序被初始化。
ABEntry::ABEntry(const std::string &name,const std::string &address,const std::list<PhoneNumber> &phones)
{
theName=name; //这些都是赋值(assignment)而非初始化(initialization)
theAddress=address; //这会导致首先调用default构造函数为theName,theAddress,thePhones设初值,然后立刻再对它们赋予新值
thePhones=phones; //default构造函数的一切作为被浪费了
numTimeConsulted=0;
}
ABEntry::ABEntry(const std::string &name,const std::string &address,const std::list<PhoneNumber> &phones)
:theName(name),theAddress(address),thePhones(phones),numTimeConsulted(0);
{
//这些都是初始化(initialization)而非赋值(assignment)
}
条款五:了解C++摸摸编写并调用那些函数
一般不能对内含reference成员或者内含const的classes支持赋值操作。如果你要这么做的话就必须要自己定义copy assignment 操作符。
条款六: 若不想使用编译器自动生成的函数,就该明确拒绝
例如如果不需要拷贝构造函数和copy assignment 操作符时,一旦有人调用他们时却会自动默认构造出来。所以只能将函数声明为private而且故意不实现他们。
class HomeForSale
{
public:
...
private:
HomeForSale(const HomeForSale &); //只有声明
HomeForSale & operator=(const HomeForSale &);//没有实现
}
条款七:为多态基类声明vitrual析构函数
1.任何class只要有virtual函数几乎确定应该也有一个virtual析构函数。如果一个class中不含virtual函数,通常表示它并不意图被用做一个base class.而当class不企图被当作base class,令其析构函数为virtual 往往是个馊主意。
2.只有当class内含至少一个virtual函数才为它声明virtual析构函数。
3.polymorphic(带多态性质)base class应该声明一个virtual析构函数。如果class带有任何virtual函数,它就应该拥有一个virtual析构函数。
4.Classes的设计目的如果不是作为base class使用,或不是为了具备多态性就不该声明virtual析构函数。
Effective C++ 读书笔记(1-7)的更多相关文章
- Effective STL 读书笔记
Effective STL 读书笔记 标签(空格分隔): 未分类 慎重选择容器类型 标准STL序列容器: vector.string.deque和list(双向列表). 标准STL管理容器: set. ...
- Effective STL读书笔记
Effective STL 读书笔记 本篇文字用于总结在阅读<Effective STL>时的笔记心得,只记录书上描写的,但自己尚未熟练掌握的知识点,不记录通用.常识类的知识点. STL按 ...
- effective c++读书笔记(一)
很早之前就听过这本书,找工作之前读一读.看了几页,个人感觉实在是生涩难懂,非常不符合中国人的思维方式.之前也有博主做过笔记,我来补充一些自己的理解. 我看有人记了笔记,还不错:http://www.3 ...
- Effective Java读书笔记完结啦
Effective Java是一本经典的书, 很实用的Java进阶读物, 提供了各个方面的best practices. 最近终于做完了Effective Java的读书笔记, 发布出来与大家共享. ...
- Effective java读书笔记
2015年进步很小,看的书也不是很多,感觉自己都要废了,2016是沉淀的一年,在这一年中要不断学习.看书,努力提升自己 计在16年要看12本书,主要涉及java基础.Spring研究.java并发.J ...
- Effective Objective-C 读书笔记
一本不错的书,给出了52条建议来优化程序的性能,对初学者有不错的指导作用,但是对高级阶段的程序员可能帮助不是很大.这里贴出部分笔记: 第2条: 使用#improt导入头文件会把头文件的内容全部暴露到目 ...
- 【Effective C++读书笔记】序
C++ 是一个难学易用的语言! [C++为什么难学?] C++的难学,不仅在其广博的语法,以及语法背后的语义,以及语义背后的深层思维,以及深层思维背后的对象模型: C++的难学还在于它提供了四种不同而 ...
- Effective Java 读书笔记(一):使用静态工厂方法代替构造器
这是Effective Java第2章提出的第一条建议: 考虑用静态工厂方法代替构造器 此处的静态工厂方法并不是设计模式,主要指static修饰的静态方法,关于static的说明可以参考之前的博文&l ...
- Effective C++读书笔记(转)
第一部分 让自己习惯C++ 条款01:视C++为一个语言联邦 一.要点 ■ c++高效编程守则视状况而变化,取决于你使用c++的哪一部分. 二.扩展 将c++视为一个由相关语言组成的联邦而非单一语言会 ...
- Effective C++ 读书笔记 名博客
https://www.cnblogs.com/harlanc/tag/effective%20c%2B%2B/default.html?page=3
随机推荐
- (NO.00003)iOS游戏简单的机器人投射游戏成形记(七)
因为到目前为止我都是在iOS模拟器中测试,但即便如此,也觉得按住手臂旋转时,手臂转动起来比较费劲,很难停止在玩家期望的位置上.因为手臂完全通过物理引擎的计算来移动,它有自身的惯性影响,所以很难控制. ...
- numpy教程:逻辑函数Logic functions
http://blog.csdn.net/pipisorry/article/details/48208433 真值测试Truth value testing all(a[, axis, out, k ...
- 反对网抄,没有规则可以创建目标"install" 靠谱解答
在ubuntu下遇到这个问题,原因其实很简单,你不能用WINDWOS下的方法用图形方式打开,然后点了一下按扭"解压缩",生成了一个文件夹. 的确,这个文件夹看起来和正常的没有什么区 ...
- window环境下搭建react native及相关插件
可以先浏览一下中文翻译的开发文档具体了解一下关于React Native,想要查看官方文档可以点http://facebook.github.io/react-native/docs/getting- ...
- STL - miltimap(可重映射)
#include <iostream> #include <map> #include <string> using namespace std; //Multim ...
- git remote
在git里,服务器上的仓库在本地称之为remote. 直接clone一个仓库: $: git clone git@search.ued.taobao.net:projects/search.git 另 ...
- Android NDK开发三:java和C\C++交互
转自:http://www.cnblogs.com/shangdahao/archive/2013/05/02/3053971.html 1.定义native方法并加载动态链接库: public cl ...
- MDX的实例讲解(排名前15的小例子)
MDX语句的特点: 大小写不分.members等于Members;downloads等于Downloads 维度的统计量指定要选择准确.downloads等于[Downloads] []可以少,不能多 ...
- android JNI调用机制
JNI的出现使得开发者既可以利用Java语言跨平台.类库丰 富.开发便捷等特点,又可以利用Native语言的高效. JNI是JVM实现中的一部分,因此Native语言和Java代码都运行在JVM的宿主 ...
- SharePoint 2007 单列表模糊查询SPD定制
应用场景:项目中总会遇到一些列表,存着是用户.项目等数据,而我们需要查询有哪些项目,这时候,就需要用到模糊查询了,而这样的查询,基本不需要跨列表,所以,也没必要配置复杂的搜索,用Designer(简称 ...