Using Object.wait(millisec) to simulate sleep

后端 未结 3 1386
庸人自扰
庸人自扰 2021-01-06 02:15

Here\'s a snippet of code that I saw in some code I\'m maintaining.

Object lock = new Object();

synchronized( lock ) 
{
   try
   {
       lock.wait( 50000          


        
相关标签:
3条回答
  • 2021-01-06 02:49

    Aside from having to get a monitor before waiting() there's no major difference anymore so long as no one external is going to be .notify()ing.

    In ancient Java code you'd see people using wait() instead of Thread.sleep() because Thread.sleep() would freeze the whole application on systems without preemptive multitasking (I'm looking at you OS9). Technically wait() also let's you use nano-resolution waits, but in practice they're seldom that accurate.

    0 讨论(0)
  • 2021-01-06 02:52

    Note that there is one key difference in using Object.wait() and Thread.sleep() inside a synchronization block: Thread.sleep() does not release the locked monitor, so no-one else can become the owner of the monitor.

    In addition, Object.wait() does not guarantee that the delay indicated will be obeyed strictly. First of all, after the delay passes, the thread may still be waiting for another thread that has become the monitor owner in the meantime; and it may compete with other threads waiting to grab the monitor.

    Second, the mythical spurious wake-up, as it is described in the Java 6 API javadoc:

    A thread can also wake up without being notified, interrupted, or timing out, a so-called spurious wakeup.

    Unlikely as it is, every piece of code using Object.wait() should take it into consideration.

    0 讨论(0)
  • 2021-01-06 02:54

    You say it's "obviously" bad form to use wait/notify for this, but I don't see anything wrong with it. Admittedly following it up with a sleep call is very odd (and swallowing exceptions is bad), but I've definitely used Object.wait as a "breakable sleep" before now.

    Imagine you've got a thread polling a resource every minute, but you want to be woken if something's happened (e.g. the resource location has changed, or the timer frequency has changed, or the program wants to quit in a graceful manner). Using wait/notify works extremely well for that - it's definitely cleaner than calling interrupt on the thread from elsewhere, as it doesn't matter if the notify occurs while you're actually processing instead of waiting.

    0 讨论(0)
提交回复
热议问题