`
cloudeagle_bupt
  • 浏览: 536379 次
文章分类
社区版块
存档分类
最新评论

我见过的关于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中恢复过来,继续执行后面的语句。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics