Java Thread.sleep()实现

时间:2012-12-25 00:37:12

标签: java multithreading concurrency thread-sleep

有人可以帮我理解Thread.sleep()函数是如何实现的吗?当指定的时间过去或某些其他线程中断时,线程将恢复/唤醒。我有兴趣了解这项工作背后的设计模式。

据说睡眠对CPU消耗没有影响。当前线程是否已添加到侦听器列表中?什么时候会检查中断标志?调度程序是否继续检查每个“x”时间内正在休眠的每个线程的中断状态(基于操作系统支持的内容)?线程如何在不影响CPU的情况下获得控制权。

我搜索过这个。很抱歉,如果我错过了任何容易找到的链接。

1 个答案:

答案 0 :(得分:13)

  

有人可以帮我理解Thread.sleep()函数是如何实现的吗?

它在操作系统提供的底层本机线程上调用sleep

  

据说睡眠对CPU消耗没有影响。

未运行的线程不占用CPU时间。

  

当前线程是否已添加到侦听器列表中?

没有。

  

何时会检查中断标志?

线程无法检查中断标志,因为它没有运行。如果请求,操作系统可以唤醒线程。

  

调度程序是否继续检查每个“x”时间内正在休眠的每个线程的中断状态(基于操作系统支持的内容)?

没有

  

线程如何在不影响CPU的情况下获得控制权。

当时间到期时,操作系统会自动唤醒该线程,或者另一个线程可以要求操作系统提前唤醒它。


以下是OpenJVM中的Thread.sleep()背后的一些代码:

 2811     ThreadState old_state = thread->osthread()->get_state();
 2812     thread->osthread()->set_state(SLEEPING);
 2813     if (os::sleep(thread, millis, true) == OS_INTRPT) {
 2814       // An asynchronous exception (e.g., ThreadDeathException) could have been thrown on
 2815       // us while we were sleeping. We do not overwrite those.
 2816       if (!HAS_PENDING_EXCEPTION) {
 2817         HS_DTRACE_PROBE1(hotspot, thread__sleep__end,1);
 2818         // TODO-FIXME: THROW_MSG returns which means we will not call set_state()
 2819         // to properly restore the thread state.  That's likely wrong.
 2820         THROW_MSG(vmSymbols::java_lang_InterruptedException(), "sleep interrupted");
 2821       }
 2822     }
 2823     thread->osthread()->set_state(old_state);