来源:


一、来源类:

  • sleep是Thread类的静态方法; 
  • wait是Object的方法,可以对任意一个对象调用wait方法

二、使用范围:

  • sleep可以在任何地方使用,必须捕获异常; 
  • wait只能在同步控制方法或者同步控制块里面使用,不需要捕获异常

三、锁:

  • sleep不释放锁,不出让锁资源,但会让出CPU资源; 
  • wait释放了锁,进入线程等待池等待,出让系统资源(锁资源和CPU资源)

线程的资源有不少,但应该包含CPU资源和锁资源这两类。


   (1)sleep(long mills):让出CPU资源,但是不会释放锁资源。

   (2)wait():让出CPU资源和锁资源。

    锁是用来线程同步的,sleep(long mills)虽然让出了CPU,但是不会让出锁,其他线程可以利用CPU时间片了,但如果其他线程要获取sleep(long mills)拥有的锁才能执行,则会因为无法获取锁而不能执行,继续等待。

    但是那些没有和sleep(long mills)竞争锁的线程,一旦得到CPU时间片即可运行了。



四、唤醒: 

  • sleep(ms) 将一个线程睡眠并指定时间自动醒,如果时间不到可以调用interreput()来强行打断; 
  • wait() 将一个线程挂起,直到超时或者该线程被唤醒。

五、施加者是有本质区别

  • 两者都可以让线程暂停一段时间,但是本质的区别是一个线程的运行状态控制,一个是线程之间的通讯的问题
  • sleep()是让某个线程暂停运行一段时间,其控制范围是由当前线程决定,也就是说,在线程里面决定.好比说,我要做的事情是 “点火->烧水->煮面”,而当我点完火之后我不立即烧水,我要休息一段时间再烧.对于运行的主动权是由我的流程来控制.
  • 而wait(),首先这是由某个确定的对象来调用的,将这个对象理解成一个传话的人,当这个人在某个线程里面说”暂停!”,也是 thisOBJ.wait(),这里的暂停是阻塞,还是”点火->烧水->煮饭”,thisOBJ就好比一个监督我的人站在我旁边,本来该线程应该执行1后执行2,再执行3,而在2处被那个对象喊暂停,那么我就会一直等在这里而不执行3,但正个流程并没有结束,我一直想去煮饭,但还没被允许, 直到那个对象在某个地方说”通知暂停的线程启动!”,也就是thisOBJ.notify()的时候,那么我就可以煮饭了,这个被暂停的线程就会从暂停处继续执行.