继承中:纯虚函数、虚函数、普通成员函数的区别

来源:互联网 发布:不root备份应用数据 编辑:程序博客网 时间:2024/06/08 13:52

1、基类中的纯虚函数:它的言外之意就是指必须在继承了它的任何具体类中重新声明,而且它们在抽象类中往往没有定义。再次重述:纯虚函数可以在基类中有定义, 也可以没有定义。但必须在子类中重新声明和定义。

“定义纯虚函数的目的在于,使派生类仅仅只是继承函数的接口”

 

2、基类中的(非纯)虚函数:它的言外之意是指派生类继承了函数的接口,但简单虚函数一般还提供了实现,派生类可以选择改写它们或不改写它们。再次重述:一般的虚函数在基类中必须要实现,我们称作缺省实现。如果在基类中只有声明,没有实现,连编译都无法通过。在子类中可以重新声明并重新定义(我们称作改写),也可以在子类中重新声明但不提供定义,或者不声明,不定义(我们称子类不进行改写),但这样做根本上没有什么意义。

“声明简单虚函数的目的在于,使派生类继承函数的接口和缺省实现”

 

3、基类中的普通成员函数:“当一个成员函数为非虚函数时,它在派生类中的行为就不应该不同。实际上,非虚成员函数表明了一种特殊性上的不变性,因为它表示的是不会改变的行为 ---- 不管一个派生类有多特殊。”

“声明非虚函数的目的在于,使派生类继承函数的接口和强制性实现”

原创粉丝点击