Effective C++ 随笔(5)

条款27:尽量稍作转型动作

const_cast:常量性移除

dynamic_cast:安全向下转型

reinterpret_cast:

static_cast:

如在子类当中享调用父类当中的某个方法,尝试使用转型方式,将其转换为父类的方式是不对的

static_cast<fclass>(*this).function();

function执行的是在一个临时对象上,而不是当前对象的父类上。如要调用父类方法,需使用下属方式 fclass::function();

条款30:透彻理解inlining的里里外外

正确声明inline函数的方法是在其定义式前面加上inline

inline函数无法随着程序库的升级而升级,一旦程序库设计者将inline函数改变,则客户程序需要重新编译, 但是如果是非inline函数则不会有这个问题,若使用动态链接的方式则更容易解决

条款31:将文件件的编译已存关系降至最低

在头文件当中使用声明的方式引入需要使用的类,需要引进的类的头文件在源文件当中include,从而,当外部类发生变化时,include文件当中的声明并没有变化, 因此不会引起不必要的重新编译;在定义当中同样应该使用指针挥着引用,因为两者的大小不变,当他们所代表的类型发生变化时,也不会引起他们的重新编译

条款33:避免掩盖集成而来的名称

在子类当中定义重新定义的和父类中同名的函数会覆盖父类中所有的同名函数,及时参数不同

例如:

class class1{

	virtual f1();

	virtual f1(int x);

}



class class2:public class1{

	f1();

}



class1 * c1 = new class2();



c1->f1();

c1->f1(1);

 会出错,因为f1(int)已经被掩盖

下面的方法可以通过

class class2:public class1{

	pubic:

	using class1::f1;

	f1();

}



c1->f1();

c1->f1(1);

 这时是没有问题的

条款35:考虑virtual函数之外的其他选择

将virtual函数变为private从而,对其进行的继承子类都会无法看到里面的细节,调用使用一个在父类当中设定的一个非virtual 函数

这样就类似于在父类设定了一个template,而在子类当中对这些template要调用的方法进行了定义

条款37:绝不重新定义继承而来的缺省参数

virtual 函数系动态绑定,而缺省参数值却是静态绑定的

你可能感兴趣的:(effective)