В следующем коде, каким образом деструкторы b
, q
и e
вызываются и вызывается перед обработкой исключения. (The "соиЬ ..." части остатки первоначального вопроса)Захватывая параметр исключения по значению, каков порядок вызова деструкторов?
#include <iostream>
using namespace std;
class A {
public:
A(int arg) : m(arg) {
cout << "A::A(int) " << m << endl;
m = 2*arg;
}
virtual void f() {
cout << "A::f() " << m << endl;
}
void g() {
cout << "A::g(A) " << m << endl;
}
int m;
};
class B : public A {
public:
B(int arg) : A(arg) {
cout << "B::B(int) " << m << endl;
m = 3*arg;
}
~B() {
cout << "B::~B()" << endl;
}
void f() {
cout << "B::f(A&) " << m << endl;
}
virtual void g() {
B q(*this);
throw q;
cout << "B::g(A) " << m << endl;
}
};
int main() {
try {
B b(1);
b.g();
} catch (A e) {
cout << "Error: ";
e.f();
}
return 0;
}
Если это возможно, могли бы вы объяснить причину. Спасибо.
'b' никогда не имеет своего деструктора, потому что он никогда не удаляется. (то есть: вы просачиваетесь.) – GManNickG
Я отредактировал код как статическое распределение. Спасибо. – hizki
@hizki: Это фактически автоматическое распределение (распределение стека) теперь, а не статическое распределение. – GManNickG