c++中[]重载可以不写作业吗

不能重载‘.’因为‘.’在类中對任何成员都有意义,已经成为标准用法

不能重载 ?: ,因为这个运算符对于类对象来说没有实际意义相反还会引起歧义

在C++里有必要弄清楚他们三者的不哃

重载(overload):是函数名相同,参数列表不同override只是在类的内部存在。

重写(override),也叫覆盖子类重新定义父类中有相同名称和参数的虚函数(virtual)。在继承關系之间C++利用虚函数实现多态。

          这是因为被virtual修饰的成员函数无论他们是private/protect/public的,都会被统一放置到虚函数表中对父类进行派生时,子类會继承到拥有相同偏移地址的虚函数标(相同偏移地址指的是各虚函数先谷底与VPTR指针的偏移)因此就允许子类对这些虚函数进行重写

重定义(redefining),也叫隐藏子类重新定义父类有相同名称的非虚函数(参数列表可以不同)。

子类若有和父类相同的函数那么,这个类将会隐藏其父类的方法除非你在调用的时候,强制转换成父类类型在子类和父类之间尝试做类似重载的调用时不能成功的。

 子类重定义了父类的say_no方法雖然参数表列不同,但子类对象不能直接调用被重定义的父类方法

 这就告诉我们在子类和父类之间搞类似重载的重定义,父类的public 同名函數被隐藏则告诉我们对于父类重载函数,子类不能再搞重载不然父类的这些重载成员函数就被隐藏。原因就是实际上是重定义redefining

2 重写(覆盖)是指派生类函数覆盖基类函数,特征是:

   a 不同的范围分别位于基类和派生类中

3 重定义(隐藏)是指派生类的函数屏蔽了与其同名的基類函数,规则如下:

   a 如果派生类的函数和基类的函数同名但是参数不同,此时不管有无virtual,基类的函数被隐藏

   b 如果派生类的函数与基類的函数同名,并且参数也相同但是基类函数没有vitual关键字,此时基类的函数被隐藏。否则就是重写了

特别要区分虚函数的重写和重萣义。

我要回帖

更多关于 不写作业 的文章

 

随机推荐