我见过的关于notify()和notifyAll()区别的最简洁的代码

转自: http://wangacidlemon.iteye.com/blog/398623


wait()方法表示,放弃当前对资源的占有权,等啊等啊,一直等到有人通知我,我才会运行后面的代码。
notify()方法表示,当前的线程已经放弃对资源的占有,
通知等待的线程来获得对资源的占有权,但是只有一个线程能够从wait状态中恢复,
然后继续运行wait()后面的语句;
notifyAll()方法表示,当前的线程已经放弃对资源的占有,
通知所有的等待线程从wait()方法后的语句开始运行。
读出什么区别没有?
上例子,先是一个nofiyAll()的例子:

Java代码收藏代码
  1. packagecom.thread.wait;
  2. publicclassWait{
  3. privateintcounter=0;
  4. privateStringname=null;
  5. publicWait(intcounter,Stringname){
  6. this.counter=counter;
  7. this.name=name;
  8. }
  9. publicsynchronizedvoiddoSomthing(){
  10. inttempCounter=--counter;
  11. if(tempCounter<=0){
  12. customizedNotifyAll();
  13. }
  14. else
  15. {
  16. while(tempCounter>0){
  17. try{
  18. System.out.println(Thread.currentThread().getName()+"-<"+name+tempCounter+">"+"willinvokeWAIT()");
  19. --tempCounter;
  20. wait();
  21. }catch(InterruptedExceptione){
  22. e.printStackTrace();
  23. notifyAll();
  24. }
  25. System.out.println(Thread.currentThread().getName()+"-<"+name+tempCounter+">"+"hasbeenACTIVED");
  26. }
  27. customizedNotifyAll();
  28. }
  29. }
  30. publicvoidcustomizedNotifyAll(){
  31. notifyAll();
  32. System.out.println(Thread.currentThread().getName()+"-<"+name+counter+">"+"::"+"INVOKEDNOTIFYALL()ANDFINISHED");
  33. }
  34. }

Java代码收藏代码
  1. packagecom.thread.wait;
  2. publicclassTestThreadimplementsRunnable{
  3. privateWaitwait;
  4. publicTestThread(Waitwait){
  5. this.wait=wait;
  6. }
  7. publicvoidrun(){
  8. wait.doSomthing();
  9. }
  10. publicstaticvoidmain(String[]args){
  11. Waitwait=newWait(4,"DAVID");
  12. Threadt1=newThread(newTestThread(wait));
  13. Threadt2=newThread(newTestThread(wait));
  14. Threadt3=newThread(newTestThread(wait));
  15. Threadt4=newThread(newTestThread(wait));
  16. t1.start();
  17. t2.start();
  18. t3.start();
  19. t4.start();
  20. }
  21. }

运行的结果:
Thread-0-<DAVID3>will invoke WAIT()
Thread-1-<DAVID2>will invoke WAIT()
Thread-2-<DAVID1>will invoke WAIT()
Thread-3-<DAVID0>::INVOKED NOTIFYALL() AND FINISHED
Thread-0-<DAVID2>has been ACTIVED
Thread-0-<DAVID2>will invoke WAIT()
Thread-1-<DAVID1>has been ACTIVED
Thread-1-<DAVID1>will invoke WAIT()
Thread-2-<DAVID0>has been ACTIVED
Thread-2-<DAVID0>::INVOKED NOTIFYALL() AND FINISHED
Thread-0-<DAVID1>has been ACTIVED
Thread-0-<DAVID1>will invoke WAIT()
Thread-1-<DAVID0>has been ACTIVED
Thread-1-<DAVID0>::INVOKED NOTIFYALL() AND FINISHED
Thread-0-<DAVID0>has been ACTIVED
Thread-0-<DAVID0>::INVOKED NOTIFYALL() AND FINISHED
看到了吧,一旦调用notifyAll()方法,所有的等待线程都会从调用wait()方法的地方继续运行起来。
这个运行结果可能每次都不一样,有时候只有两个线程运行完成而其余两个线程在等待其它线程调用notifyAll()方法,有时候只有三个线程运行完成,而另一个还在等待中。
由于本文是讲解notify以及notifyAll方法,所以对上面的原因不多加以解释。
然后是notify()方法的例子:
就是将wait类中的customizedNotifyAll()方法中的notifyAll()方法换成notify()方法
运行结果:
Thread-1-<DAVID3>will invoke WAIT()
Thread-0-<DAVID2>will invoke WAIT()
Thread-2-<DAVID1>will invoke WAIT()
Thread-3-<DAVID0>::INVOKED NOTIFYALL() AND FINISHED
Thread-1-<DAVID2>has been ACTIVED
Thread-1-<DAVID2>will invoke WAIT()
Did you see that?所有的等待线程中,只有一个线程运行完成了,而其它的线程还在傻傻地等待,poor guys!
每次运行的结果会不一样,但是始终只有一个线程能够运行完成。
Summary:
notify()方法只是让一个线程从wait中恢复过来,至于具体是哪个,那就得看那些线程的运气了(不设置优先级的情况下),继续执行后面的语句;
notifyAll()方法是让所有的线程从wait中恢复过来,继续执行后面的语句。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值