学而不思则罔,思而不学则殆
sleep方法介绍
sleep是一个静态方法,有两个重载方法,一个需要传入毫秒数,另一个需要毫秒数和纳秒数。
public static native void sleep(long millis) throws InterruptedException;
public static void sleep(long millis, int nanos)
...
sleep(millis);
}
该方法会使当前线程进入指定的时间进入休眠,暂停执行。而且有一个非常重要的特性,进入休眠后,不会释放monitor锁的所有权,仍然持有锁。
例子
private static void testSleep() {
try {
System.out.println("start:" + System.currentTimeMillis());
TimeUnit.SECONDS.sleep(5);
System.out.println("end:" + System.currentTimeMillis());
} catch (InterruptedException e) {
e.printStackTrace();
}
}
start:1598832046641
end:1598832051641
相差5s
范例二
private static void testSleep() {
synchronized (TestMain.class) {
try {
System.out.println("start:" + System.currentTimeMillis());
TimeUnit.MINUTES.sleep(10);
System.out.println("end:" + System.currentTimeMillis());
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
此时一直持有静态类锁,不会释放。
通过Jconsole工具查看,没有释放锁。
在通过jstack工具查看堆栈信息:
"main" #1 prio=5 os_prio=0 tid=0x00000000027de800 nid=0x29ec waiting on condition [0x000000000275f000]
java.lang.Thread.State: TIMED_WAITING (sleeping)
at java.lang.Thread.sleep(Native Method)
at java.lang.Thread.sleep(Thread.java:340)
at java.util.concurrent.TimeUnit.sleep(TimeUnit.java:386)
at com.thread.TestMain.testSleep(TestMain.java:19)
- locked <0x000000074069c9f0> (a java.lang.Class for com.thread.TestMain)
at com.thread.TestMain.main(TestMain.java:11)
同样持有了类锁com.thread.TestMain,没有释放锁,当sleep的时候。
每个线程的休眠互不影响,Thread.sleep只会导致当前线程进入指定时间的休眠