Effective C++ 1-6
最后更新于:2022-04-01 15:49:33
1.尽量用const 和inline 而不用#define:
即尽量用编译器,而不是预处理。宏命令导致编译器永远看不到被声明为宏的符号名,而编译器的处理会进行一些错误判断,但预处理不会。
如果出错,调试无法找到宏声明的错误来源,因为这些符号不存在于符号列表中。
宏调用时会出错,如使用自加或自减操作符时。宏应该使用inline 内联函数代替。
在类中可以使用enium来代替宏,如下,在类中声明一个枚举,枚举中设置一些值,就可以当作常量在类的其他地方随意使用了。
~~~
class A{
public:
enum CHECKED { YES = 1,NO = 0};
int a;
A(int x,CHECKED = YES){}
}
~~~
2.尽量使用<iostream>而不是<stdio.h>
scanf和printf很轻巧高效,但cout<<和cin>>具有类型安全和扩展性。使用<<和>>操作符重载:
~~~
friend ostream& operator<<(ostream& s,const D& d);
~~~
但是iosteam的有些操作要比C stream的效率低,且可移植性低。
对于c++中是否在头文件后加.h,未加表示库中元素都在std命名空间中,加后表示元素为全局空间的。使用前者会避免名字冲突。
3.尽量使用new和delete 而不用malloc和free。
malloc和free在c中有用,但是无法用于c++中的类与对象,c++中构造函数和析构函数,可以动态的分配内存。
且malloc和free是库函数,而new和delete是操作符。
4.尽量使用c++风格的注释.。
c++风格为行尾注释语法使用//,而c风格的使用/* ... */。
5.对应的new和delete 要采用相同的形式。
要删除的是单个对象还是数组,需要告诉delete。出错的结果是不可预测的。
而当使用typedef来定义类型后,new这个类型,也要用相应形式的真正的类型来delete进行删除,如:
~~~
typedef string AddressLines[5];
~~~
要释放new的AddressLines对象,要用真正的形式,即delete [] p。
6.析构函数中对指针成员调用delete、
大多数情况下,执行动态内存分配的类都在构造函数中进行new分配内存,而在析构函数中使用delete来释放内存。
而当程序不断维护升级后,在其他成员函数中会不断的添加新的指针,所以一定要在析构函数中都进行删除。
指针要初始化,不然会在析构时出错。而删除空指针是安全的,因为它什么也没做。