Je regarde un exemple de comportement des fonctions virtuelles. Compte tenu de ce code de test, j'ai quelques questions quant à son comportement.Incompatibilité de signature de fonction virtuelle et son comportement
class A
{
public:
A(int x)
{
cout << "In A Constructor" << endl;
print();
}
~A(){
cout << "In A Destructor" << endl;
delete _val;
}
virtual void print() { cout << "A." << endl; }
private:
char* _val;
};
class B: public A
{
public:
B(int x, int y) : A(x)
{
_dVal = new char[y];
cout << "In B Constructor 1" << endl;
print();
}
B() : A(0)
{
_dVal = new char[1];
cout << "In B Constructor 2" << endl;
print();
}
~B(){
cout << "In B Destructor" << endl;
delete _dVal;
}
void print() { cout << "B" << endl; }
private:
char* _dVal;
};
int main(int argc, char** argv) {
A* p1 = new B();
p1->print();
delete p1;
return 0;
}
La sortie est:
In A Constructor
A.
In B Constructor 2
B
B
In A Destructor
1) Pourquoi l'impression appelé pour la classe B si la classe A est le seul désignant comme une fonction virtuelle et il est appelé par déréférencer (->)? 2) Pourquoi le destructeur de B n'est-il jamais appelé si le constructeur est appelé?
Si la fonction est virtuelle dans la classe de base, elle est également virtuelle dans toutes les classes dérivées. Idem pour le destructeur. –
Une question par question s'il vous plaît. –