Was passiert im folgenden Beispiel?Basisklassenreferenz - weisen Sie einen anderen Typ zu
struct B { };
struct D1 : B { };
struct D2 : B { };
int main()
{
D1 d;
D2 d2;
B& x = d;
x = d2;
}
Ich weiß, dass die Referenz nicht neu zugewiesen wird. x
bezieht sich immer noch auf d
, aber wie können Sie dann d2
zu d
zuweisen?
Einige mehr:
struct B
{
B() { x = 0; }
int x;
virtual void foo() { cout << "B" << endl; }
};
struct D1 : B
{
D1() { x = 1; }
virtual void foo() { cout << "D1" << endl; }
};
struct D2 : B
{
D2() { x = 2; }
virtual void foo() { cout << "D2" << endl; }
};
int main()
{
D1 d;
D2 d2;
B& x = d;
x.foo(); //D1
//x.x is 1 here
x = d2;
x.foo(); //also D1
//but x.x is 2 here
}
Es scheint, wie x.x
wurde aktualisiert, aber die vftable war nicht ... Warum?
+1. Gute Frage. – Nawaz