• Thread.sleep(long):从本线程调用,让当前线程睡眠,可能睡眠被interrupt方法打断而抛出InterruptedException异常。
  • t1.interrupt():从其他线程调用,将t1线程的sleepwaityield打断,强制唤起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状态,需要获得锁才能再次执行。