Thread.sleep(long)
:从本线程调用,让当前线程睡眠,可能睡眠被interrupt
方法打断而抛出InterruptedException
异常。t1.interrupt()
:从其他线程调用,将t1
线程的sleep
、wait
、yield
打断,强制唤起t1
线程。此时可以在t1
线程内部的调用Thread.curruptThread().inInterrupted()
查看是否被其他线程打断,并且只能使用一次(如果在睡眠时被打断,那么还是会为false,但是此时会抛出异常,可以在catch语句中再次调用Thread.curruptThread().interrupt()
,此技巧为两阶段终止模式),然后执行对应的逻辑。作用:可以在其他线程优雅的关闭t1
线程,让t1
线程有机会关闭资源。Thread.yield()
:从本线程调用,请求让出CPU(但是不一定成功)t1.join()
和t1.join(long)
:从其他线程调用,阻塞当前线程(进入WAIT状态,让t1
线程插队),等待t1
线程执行结束后再继续执行。t1.getState()
:获得线程当前运行状态。lock.wait()
、lock.wait(long)
:在本线程中调用,让自己进入WAIT状态(只有获得了锁才能调用此方法),该方***放弃自己持有的锁,被唤醒之后还是会处于BLOCKED状态,需要等待锁。配合while
使用可以解决虚假唤起的问题。lock.notify()
、lock.notifyAll()
:在本线程调用,并且获得锁之后才能调用,调用之后可以从锁的Monitor阻塞队列中选择一个线程唤醒,但是被唤醒的线程会处于BLOCKED状态,需要获得锁才能再次执行。