A
Amit Dedhia
Hi
I am developing an application using C++/CLI in Visual Studio 2005. In
my application I have following structure.
(1) Class A creates instances of Class B and Class C.
(2) Class B implements a timer function which repeatedly executes a
timer every 250 ms.
(3) Class C instance hooks for a event raised by Class B instance.
Class B always raises this event asynchronously at the end of timer
function. In the event handler class C raises another event which is
hooked by Class A.
(4) The event handler in class A eventually update the main UI control
(using control->Invoke() which executes on main thread)
Now, Class A's destructor is called from the main application thread.
In the destructor, class A first calls destructor of class B. Class
B's destructor returns after the timer is properly destroyed.
Then class A tries to unhook the class C's event. Here it hangs!!! The
unhook code is standard event unhook code using -= operator.
Can anyone guess why it hangs? In the thread window I saw that the
event handler in class A (for the event raised by class C) was waiting
on control->Invoke() method. However it does not explain to me why the
class A hangs at the point of unhooking an event raised by class C. Is
it reqd that the event handlers must be completely executed before it
can be unhooked? I dont think so. There is definitely a deadlock
situation here. But I am not able to guess it?
Anyone?
Thanks in advance
Amit Dedhia
I am developing an application using C++/CLI in Visual Studio 2005. In
my application I have following structure.
(1) Class A creates instances of Class B and Class C.
(2) Class B implements a timer function which repeatedly executes a
timer every 250 ms.
(3) Class C instance hooks for a event raised by Class B instance.
Class B always raises this event asynchronously at the end of timer
function. In the event handler class C raises another event which is
hooked by Class A.
(4) The event handler in class A eventually update the main UI control
(using control->Invoke() which executes on main thread)
Now, Class A's destructor is called from the main application thread.
In the destructor, class A first calls destructor of class B. Class
B's destructor returns after the timer is properly destroyed.
Then class A tries to unhook the class C's event. Here it hangs!!! The
unhook code is standard event unhook code using -= operator.
Can anyone guess why it hangs? In the thread window I saw that the
event handler in class A (for the event raised by class C) was waiting
on control->Invoke() method. However it does not explain to me why the
class A hangs at the point of unhooking an event raised by class C. Is
it reqd that the event handlers must be completely executed before it
can be unhooked? I dont think so. There is definitely a deadlock
situation here. But I am not able to guess it?
Anyone?
Thanks in advance
Amit Dedhia