我正在查看虛擬功能行爲的示例情況。鑑於這個測試代碼,我有幾個關於它的行爲的問題。虛擬功能簽名不匹配及其行爲
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;
}
的輸出是:
In A Constructor
A.
In B Constructor 2
B
B
In A Destructor
1)爲什麼被稱爲B類打印如果類A是唯一一個表示它作爲一個虛函數和它正被解除引用(稱爲 - > )? 2)如果構造函數實際上被調用,爲什麼B的析構函數永遠不會被調用?
如果函數在基類中是虛擬的,那麼它在所有派生類中也是虛擬的。同樣是析構函數。 –
請問每個問題一個問題。 –