Signals lib - causes mysterious multiple destructor calls
data:image/s3,"s3://crabby-images/0d4c5/0d4c58ebb7f9a97f368a44858c9376a47cbeb2c5" alt=""
Testing out the Boost signals lib, I wrote:
-----------
#include
data:image/s3,"s3://crabby-images/6bf79/6bf799e4b7568a3f28ee28c9e24cd05cbf93b60e" alt=""
Chuck Messenger said:
Testing out the Boost signals lib, I wrote:
----------- #include
#include <iostream> using namespace std; using namespace boost;
struct X { void operator()(int val) { cout << "X <- " << val << endl; } X() { cout << "X constructor\n"; } ~X() { cout << "X destructor\n"; } };
int main() { { cout << " phase 1\n"; signal
sig; cout << " phase 2\n"; X x; cout << " phase 3\n"; sig.connect(x); cout << " phase 4\n"; } cout << " phase 5\n"; return 0; } -------------------
The following output is generated (gcc3.2.2 on Mandrake 9.1):
------------------------ phase 1 phase 2 X constructor phase 3 X destructor X destructor X destructor X destructor X destructor X destructor X destructor X destructor phase 4 X destructor X destructor phase 5 ------------------------
Why the multiple calls to X's destructor? I'd have expected just one. It looks like the signals lib is misbehaving.
No, it's not. X is being destructed as many times as it's being constructed. What's missing to help you see this is a user defined copy constructor for X. -- William E. Kempf
data:image/s3,"s3://crabby-images/a0aac/a0aaccf2af0f8ed98075ff9f6ba42f4a71fdb114" alt=""
William E. Kempf wrote:
Chuck Messenger said:
Why the multiple calls to X's destructor? I'd have expected just one. It looks like the signals lib is misbehaving.
No, it's not. X is being destructed as many times as it's being constructed. What's missing to help you see this is a user defined copy constructor for X.
Oh. Duh. Thanks! - Chuck
participants (3)
-
Chuck Messenger
-
Chuck Messenger
-
William E. Kempf