¿Qué sucede en el siguiente ejemplo?Referencia de clase base: asigne otro tipo a ella
struct B { };
struct D1 : B { };
struct D2 : B { };
int main()
{
D1 d;
D2 d2;
B& x = d;
x = d2;
}
Sé que la referencia no se reasigna. x
todavía se refiere a d
, pero ¿cómo se puede asignar d2
a d
?
Algunos más:
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
}
Parece que x.x
se ha actualizado, pero el vftable no era ... ¿Por qué?
+1. Buena pregunta. – Nawaz