C++基础知识面试必备、复习细节 (5) {Effective c++}
尽可能延后变量定义式的时间
尽可能推迟定义变量,只有在真正要使用的时候再定义,最好在需要初始化时定义,即定义时就立刻初始化。
尽量少做转型动作
尽量避免使用cast,必须使用cast的情况下,应尽量将cast置于函数内部
避免返回一个指针、引用或者迭代器指向类内的成员
原因是如果返回了成员的引用或者指针,就可以通过这个引用或者指针修改类内的private成员
努力处理异常
当异常被抛出时,要做到不泄露任何资源,不允许数据败坏。
inline函数
尽量将inline用在小型、被频繁调用的函数身上,便于之后调试,同时提升程序速度的同时减小代码膨胀问题
inline只是一种申请,编译器会根据具体情况来决定一个函数是否可以是inline得,比如递归函数、virtual函数、代码较多的函数,即使你声明了inline关键字,编译器也不会将此类函数视为inline的函
将文件间的编译依存关系降至最低
尽量让头文件不依赖其他文件,以对声明的依赖取代对定义的依赖
确保public继承表示的是"is a"关系
也就是说,派生类是一个基类,基类上的每一个事情都使用于派生类
名称遮掩问题
子类会遮掩父类同名的函数,可以使用类名作用域决定调用父类还是子类的函数。
区分接口继承和实现继承
在public继承下,派生类总是会继承基类的接口。
对于纯虚函数只继承接口,子类必须重载该函数;对于非纯虚函数继承接口并存在默认的实现继承,普通函数则继承接口及并强制继承其实现。
考虑virtual函数以外的其他选择
不要重新定义继承而来的非虚函数
non-virtual在实现上是静态绑定的,调用父类还是子类的函数完全取决于指针或者对象的类型。在子类重定义non-virtual时,父类的相同的函数是不会被覆盖的
不要重新定义继承而来的默认参数
通过复合composition塑造出has-a或"根据某物实现出"
在应用域,复合意味着has-a,在实现域,符合以为着 根据某物实现出
明确私有继承
由private base class继承而来的所有成员,在derived class中都会变成private属性
慎重使用多重继承
了解typename
声明template参数时,前缀关键字class和typename可以互换
学习处理模板化基类内的名称
在子类模板中,如果要引用父类模板的name时,用this->name、using Base<T>::name声明或者基类限定(Base<T>::name)的方式。
将与template参数无关的代码抽离到模板外
原因是模板会根据具体类型具象化不同的代码,如果将与模板无关的代码也放入模板函数或者类中,那么就会生成重复的代码,就会导致代码膨胀的问题,函数模板中与参数无关的代码可以包装成单独的函数。类模板中与参数无关的模板可以放到父类中。
不要轻易忽视编译器的警告
严肃对待编译器的警告,也不要过度依赖于编译器的报警能力。