/ / Prístup k nejednoznačnému členovi triedy - c ++

Prístup k nejednoznačnému členovi triedy - c ++

Dostal som diamant. Chcem získať prístup k členovi triedy. Používam mingw.
Otázkou je: Ako získať prístup k členovi "top :: A" bez opätovného vyhlásenia tried

#include <cstdio>
class top {
public:
const char A;
top(): A("t") {}
};
class left: public top {
public:
const char A;
left():A("l"){}
};
class right: public top {};
class bottom: public left, public right {};

int main() {
bottom obj;
printf("%cn", obj.bottom::right::A); //using right::A, inherited from top::A
printf("%cn", obj.bottom::left::A); //using left::A and left::top::A is hidden
//printf("%cn", obj.bottom::left::top::A); //error. How to access it?
return 0;
}

Po odstránení komentára mi mingw spôsobí chybu:

"top" is an ambiguous base of "bottom"

Aktualizácia: Zdá sa, že typy castingu fungujú:

printf("%cn", static_cast<top>(static_cast<left>(obj)).A);
printf("%cn", static_cast<left>(obj).::top::A);
printf("%cn", reinterpret_cast<top&>(obj).A);//considered bad
printf("%cn", (reinterpret_cast<top*>(&obj))->A);//considered evil
//      printf("%cn", static_cast<top&>(obj).A);//error

odpovede:

4 pre odpoveď č. 1

Bez nutnosti virtuálneho dedičstva môžete trochu masírovať typ, aby ste presvedčili kompilátor, aby vybral správnu základnú triedu:

printf("%cn", static_cast<left&>(obj).::top::A);

2 pre odpoveď č. 2

Nie som celkom guru v C ++, ale nemohla by som nasledovať prácu?

left &asLeft = obj ;
top &asTop = asLeft ;
cout << asTop.A << endl ;

-1 pre odpoveď č. 3

Dimondov problém. Pozri http://en.wikipedia.org/wiki/Diamond_problem