虚拟继承:没有匹配函数可用于调用

时间:2018-06-24 20:54:30

标签: c++ inheritance virtual

我有以下代码。此代码用于

#include <stdio.h>
#include <iostream>
struct A {
    public:
        virtual void m1(){
            std::cout << "A virtual void m1"<<std::endl;
        }
        void m1(int a){
            std::cout << "A void m1(int)"<<std::endl;
        }
        virtual void m2(){
            std::cout << "A virtual void m2()"<<std::endl;
        }
        void m3(int a){
            std::cout << "A void m3(int)"<<std::endl;
        }
};
struct B: virtual  A{
    public:
    B():A(){}
    virtual void m1(){
        std::cout <<"B virtual void m1()" <<std::endl;
    }
    virtual void m2(int a){
        std::cout << "B virtual void m2(int a)"<<std::endl;
    }
    void m3(){
        std::cout <<"B void m3" <<std::endl;
    }
    virtual void m4(){
        std::cout <<"B void m4()" <<std::endl;
    }
};



int main() {
    B* b = new B;

    b->m1();
    b->m1(1);
    b->m2();
    b->m3(1);

    return 0;
}

当我尝试编译上述代码时,出现以下错误:

$ c++ virtual.cpp
virtual.cpp: In function ‘int main()’:
virtual.cpp:90:12: error: no matching function for call to ‘B::m1(int)’
     b->m1(1);
            ^
virtual.cpp:21:18: note: candidate: ‘virtual void B::m1()’
     virtual void m1(){
                  ^~
virtual.cpp:21:18: note:   candidate expects 0 arguments, 1 provided
virtual.cpp:91:11: error: no matching function for call to ‘B::m2()’
     b->m2();
           ^
virtual.cpp:24:18: note: candidate: ‘virtual void B::m2(int)’
     virtual void m2(int a){
                  ^~
virtual.cpp:24:18: note:   candidate expects 1 argument, 0 provided
virtual.cpp:92:12: error: no matching function for call to ‘B::m3(int)’
     b->m3(1);
            ^
virtual.cpp:27:10: note: candidate: ‘void B::m3()’
     void m3(){
          ^~
virtual.cpp:27:10: note:   candidate expects 0 arguments, 1 provided

例如,在阅读了有关虚函数的信息后,我希望我的调用b->m1(1)会解决为B::m2(int a),但显然我的代码是错误的。

我怀疑我没有正确初始化父结构,但是除了我不知道我在做什么错以外,我都不知道。

1 个答案:

答案 0 :(得分:3)

在C ++中重载继承的函数时,具有相同名称的基类函数将被隐藏。隐藏的基类函数不能像类函数那样调用,也不能像隐藏的继承函数那样被调用,您需要专门告诉编译器您要使用隐藏的函数。

您要做的就是写下定义您要使用的功能的类:theRightClass::ambiguousFunction();

在您的代码中,主要功能变为:

int main() {
    B* b = new B();

    b->m1();
    b->A::m1(1);
    b->A::m2();
    b->A::m3(1);

    delete b;

    return 0;
}