第一章生效
第一章 让自己习惯 C++(Accustoming Youself to C++)
条款1:视C++为一个语言联邦
c是一种多重范型编程语言,支持过程形式、面向对象形式、函数形式、泛型形式和元编程形式。
c被视为一个语言联盟,包括以下四个部分:
列车员:面向过程's部分
面向对象C:面向对象,的部分,包括封装、继承、多态和虚函数(动态绑定)。
模板:泛型编程部分
STL:结合了泛型编程和OOP编程思想的C++标准模板库,包括容器、迭代器、算法和函数对象。
请记住:
C++高效编程守则视状况而变化,取决于使用的是这四个部分中的哪一部分。
条款2:尽量以const,enum,inline代替#define
是的,编译器代替预处理器.
#define,即宏定义在预处理阶段处理,不进入符号表。
int a=5,b=0;
CALL_MAX(a,b);//a累计两次。
CALL_MAX(a,b 10);//a累计一次。
这是一种不可预测的行为,因此使用内联函数代替宏定义函数。
请记住:
对于单纯常量,最好使用const对象或enum替换#defines。
对于形似函数的宏,最好改用inline函数替换#defines。
条款3:尽可能使用const
Const关键字告诉编译器一个值应该保持不变,也就是说,它是只读的。
const成员函数
如果两个成员函数的恒定性不同,它们就可能被重载。
常量成员函数表示的指针类型是常量类名。
使用常量成员函数来处理常量对象。
在const和non-cons成员函数中避免重复
使用非常量版本调用常量版本,并转换常量_cast和静态_cast,例如:
const char运算符[](int pos)const;//const版本
char operator[](int pos){//非常数版本
返回常量_castchar //返回值转换,删除常量
(static _ castconst CLaSS name(* this)[pos]);//*此转换,添加常量
}
但是,用const version来调用非常数版本是错误的。
请记住:
将某些东西声明为const可以帮助编译器侦测除错误;const可以被施加在任何作用域内的对象、函数参数、函数返回类型、成员函数本身。
编译器强制实施bitwise constness,但是你编写程序时应该使用“概念上的常量性”。
当const和non-const成员函数有着实质等价的实现时,使用non-const版本来调用const版本可以避免代码重复。
条款4:确定对象使用前已被初始化
始终在使用对象之前对其进行初始化。
对于内置类型,请手动初始化。
对于非内置类型,使用构造函数进行初始化。
赋值和初始化:有不同之处
//赋值而不是初始化。
ABEntry(常量字符串名称,常量字符串地址,int num){ 0
_ name=name
_ address=address
_ num=num
}
//初始化,在进入构造器本体之前发生。
//即成员初始化列表。
ABEntry:ABEntry(常量字符串名称,常量字符串地址,int num)
: _name(姓名)、_address(地址)、_num(号码){ }
c有一个固定的初始化顺序:按照声明顺序进行初始化,且基类先于派生类初始化.
静态对象:它的生命周期是从被构造到程序结束。
局部静态对象:函数中的静态对象。
非局部静态对象:非函数中的静态对象,其初始化顺序在不同的编译单元中是不确定的。
因此,要解决非局部静态对象的初始化顺序问题,需要将非局部静态对象转换为局部静态对象(使用singleton模式,即封装一层函数)。
Singleton类
{
公众号:
静态Singleton getInstance(){ 0
静态单例;
返回s;
}
私人:
Singleton() {}
Singleton(常量Singleton);
void运算符=(const Singleton);
};
请记住:
为内置类型进行手工初始化,C++不保证初始化它们。
构造函数最好使用成员初值列,不要在构造函数中使用赋值操作,初值列中的成员变量的顺序应该和声明顺序一致。
为免除“跨编译单元之初始化次序”问题,使用返回local static对象引用的函数来代替non-local static对象。
reference
[1]有效C斯科特迈耶斯
内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/143785.html