当前位置:首页 > c++ > 重载是否对派生类起作用?

重载是否对派生类起作用?

xuwenyan2周前 (07-28)c++540

如果派生类有基类的同名方法,这是否能构成重载?

例如:

class A {
public:
  void func(float value) {
    cout << "A::func:" << value << endl;
  }
};

class B : public A {
public:
  void func(int value) {
    cout << "B::func:" << value << endl;
  }
};

int main() {
  B b;
  b.func(1.2f);

  system("pause");
  return 0;
}

由于调用func传入的是'1.2f',属于浮点数,是不是应该会调用A::func才对呢?

image.png

可以看到,执行的却是B::func,也就是说重载对派生类是没有作用的。如果非要这样重载应该怎么写呢?

派生类如何实现重载基类方法?

只需要在派生类using需要重载的基类方法即可,结果如下:

image.png

问题解决~

    文章作者:xuwenyan
    版权声明:本文为本站原创文章,转载请注明出处,非常感谢,如版权漏申明或您觉得任何有异议的地方欢迎与本站取得联系。
    标签: C++编程重载

    相关文章

    C++ 获取进程所在目录(进程全路径)

    C++ 获取进程所在目录(进程全路径)

    打开windows任务管理器,会看到很多的进程在运行,随机挑选一个,如何通过c++代码获取某一个进程的所在全路径呢?这也是在windows软件开发中经常遇到的需求。通过进程名获取进程全路径由于可能很多...

    c++函数模板参数类型限定

    c++函数模板参数类型限定

    函数模板函数模板可以实现对不同数据类型做统一操作,比如比较两个数据的大小:template<typename T> bool compare(T& ...

    排序算法-快速排序

    排序算法-快速排序

    排序算法的思想非常简单,在待排序的数列中,我们首先要找一个数字作为基准数(这只是个专用名词)。为了方便,我们一般选择第 1 个数字作为基准数(其实选择第几个并没有关系)。接下来我们需要把这个待排序的数...

    排序算法-冒泡排序

    排序算法-冒泡排序

    冒泡排序也是一种简单直观的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法...

    排序算法-选择排序

    排序算法-选择排序

    选择排序是一种简单直观的排序算法,无论什么数据进去都是 O(n²) 的时间复杂度。所以用到它的时候,数据规模越小越好。唯一的好处可能就是不占用额外的内存空间了吧。时间复杂度O(n²)最坏情况合适发生?...

    大端模式和小端模式的区别以及如何判断大小端

    大端模式和小端模式的区别以及如何判断大小端

    在计算中,字节顺序是指数字的二进制表示内的字节(或有时是位)的顺序。它也可以更普遍地用于指代任何表示的内部排序,例如数字系统中的数字或日期的部分。在最常见的用法中,字节顺序表示多字节数字内的字节顺序,...

    发表评论

    访客

    ◎欢迎参与讨论,请在这里发表您的看法和观点。