#include <iostream>
#include <string>
using namespace std;
class Person
{
string name;
public:
Person():name("")
{
cout << "Person default ctor\n";
}
Person(const string& name_in):name(name_in)
{
cout << "Person string ctor: " << name << "\n";
}
~Person()
{
cout << "Person dtor: " << name << "\n";
}
string get_name()
{
return name;
}
};
class Professor:public Person
{
int office;
public:
Professor(const string& name_in, int office_in):Person(name_in), office(office_in)
{
cout << "Professor string ctor: " << get_name() << endl;
}
~Professor()
{
cout << "Professor dtro: " << get_name() << endl;
}
};
int main()
{
Person alice("Alice");
Professor bob("Bob", 10);
return 0;
}
出力は次のようになると思います。
Person string ctor: Alice
Person dtor: Alice
Professor string ctor: Bob
Professor dtor: Bob
それはプログラムの構造から論理的に続くべきであるように思われるので。ただし、実際の出力は次のとおりです。
Person string ctor: Alice
Person string ctor: Bob
Professor string ctor: Bob
Professor dtor: Bob
Person dtor: Bob
Person dtor: Alice
誰かがこれがなぜであるか説明できますか?間違った出力を思い付く原因となっているクラス/コンストラクタ/デストラクタについて理解していないことは何ですか?