My answer was that the code does not even compile because the call to notify()/wait() are not under a synchronized block. But it throws a runtime exception, which is fixed by adding the synchronized keyword to the doStuff() method. So, when a wait()/notify()/notifyAll() are not placed under a synchronized block it'll throw a runtime exception, right? I just wanna make sure I'm concluding the right thing. There might be another reason and I haven't acknowledged ..yet..Any other observations will be highly appreciated. thx
I'm not going to be a Rock Star. I'm going to be a LEGEND! --Freddie Mercury
Hi Andres, the exception warning would be: java.lang.IllegalMonitorStateException: current thread not owner. Which is the exception generated by code that uses wait() & notify() in non-synchronised blocks.
Yes, right. Now, let�s describe what �placed under� means. wait, notify and notifyAll may be invoked only by a thread that holds the synchronization lock of the object on which the method is invoked. The invocation can be made directly in a method or block of code declared as synchronized, or can be made indirectly from a method invoked in such code. Compliance generally cannot be verified at compile time. Failure to comply causes these operations to throw an IllegalMonitorStateException at run time. You can use the static method Thread.holdsLock(Object o) in your practice programs to show you whether the current thread holds a lock. [ June 22, 2003: Message edited by: Marlene Miller ]