5

考虑我有两个纯虚拟类,一个从另一个派生,一个从最后提到的派生的具体类:

#include <iostream>
#include <string>

class Abstract1
{
public:
    virtual ~Abstract1() { };
    virtual void method(int a) = 0;

protected:
    Abstract1() = default;
};

class Abstract2: public Abstract1
{
public:
    virtual ~Abstract2() { };
    virtual void method(char c, std::string s) = 0;

protected:
    Abstract2() = default;
};

class Concrete : public Abstract2
{
public:
    void method(int a) override
    {
        std::cout << __PRETTY_FUNCTION__ << "a: " << a << std::endl;
    }

    void method(char c, std::string s) override
    {
        std::cout << __PRETTY_FUNCTION__ << "c: " << c << "; s: " << s << std::endl;
    }
};

当我创建类型的指针时,Abstract2*我无法从Abstract1.

int main()
{
    Concrete c;
    c.method(42);
    c.method('a', std::string("string"));

    Abstract2 *ptr_a2 = &c;
    ptr_a2->method(13); //Error
    ptr_a2->method('b', std::string("string2"));
}

我收到以下错误,说唯一存在的方法是Absctract2重载:

<source>: In function 'int main()':
<source>:49:22: error: no matching function for call to 'Abstract2::method(int)'

   49 |     ptr_a2->method(13);

      |                      ^

<source>:22:18: note: candidate: 'virtual void Abstract2::method(char, std::string)'

   22 |     virtual void method(char c, std::string s) = 0;

      |                  ^~~~~~

<source>:22:18: note:   candidate expects 2 arguments, 1 provided

有谁知道它为什么会发生或如何解决它?我的意思是,我得到的唯一合理的解决方案是添加

virtual void method(int a) override = 0;

课内Abstract2

这是“隐藏姓名”的情况吗?为什么只在指针上而不是在具体类上呢?参数个数不同不仅是close类型的东西。

这是创建示例的在线玩的链接: https ://godbolt.org/z/gxKpzN

4

1 回答 1

4

是的,名称隐藏在(但在声明覆盖的地方Abstract2再次可见)。Concrete使其可访问的最简单方法Abstract2是添加一条using语句:

class Abstract2: public Abstract1
{
public:
    using Abstract1::method;
    virtual void method(char c, std::string s) = 0;
};

请注意,成员函数是纯虚函数还是具有定义无关紧要,无论是查看具体Abstract2还是引用或指向 type 的指针,我们都会看到相同的结果Abstract2

于 2020-01-15T18:06:42.097 回答