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ď č. 1Bez 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