Я наткнулся на следующий код C++ в онлайн-тесте.Несколько виртуальных наследований: почему метод класса не является неоднозначным?
#include <iostream>
class A
{
public:
A(int n = 2) : m_n(n) {}
public:
int get_n() const { return m_n; }
void set_n(int n) { m_n = n; }
private:
int m_n;
};
class B
{
public:
B(char c = 'a') : m_c(c) {}
public:
char get_c() const { return m_c; }
void set_c(char c) { m_c = c; }
private:
char m_c;
};
class C
: virtual public A
, public B
{ };
class D
: virtual public A
, public B
{ };
class E
: public C
, public D
{ };
int main()
{
E e;
C &c = e;
D &d = e;
std::cout << c.get_c() << d.get_n();
c.set_n(3);
d.set_c('b');
std::cout << c.get_c() << d.get_n() << std::endl;
return 0;
}
Код выводит a2a3, но я не понимаю. Почему это выполняется на первом месте, а не методы класса B неоднозначны? Также класс E фактически не унаследован.
Почему методы 'B' были бы двусмысленными? Он ничего не перегружает, так что у него нет никаких шансов быть двусмысленным? –
Зачем вам нужно, чтобы 'E' был унаследован? Кем и зачем? –
«_Also класс E практически не наследуется». Класс 'E' вообще не унаследован. – curiousguy