网站首页 > java教程 正文
wait()、notify()和notifyAll()方法
新手不必过认真研究,有兴趣的可研究
这三个方法仅在 synchronized 方法中才能被调用。
wait()方法告知被调用的线程退出监视器马克-to-win并进入等待状态,直到其他线程进入相同的监视器并调用 notify( ) 方法。
notify( ) 方法通知同一对象上某一个调用 wait( )线程。 If any threads are waiting on this object, one of them is chosen to be awakened. The choice is arbitrary and occurs at the discretion of the implementation.
notifyAll() 方法通知调用 wait() 的所有线程,竞争胜利的线程将先运行。 The awakened threads will compete in the usual manner with any other threads that might be actively competing to synchronize on this object; the awakened threads enjoy no reliable privilege or disadvantage in being the next thread to lock this object。
结论:notifyall是竞争,而notify是由具体实施的jvm决定的。
见下例:
例1.11.1-本章源码
class DishMark_to_win {
private String food = "";
public synchronized String eat() {
try {
System.out.println("需要等一会,暂时无饭");
/* 当执行下面的wait,这个线程将会暂停在这,然后当下列serve执行notify,然后这个线程将从这继续执行。*/
wait();
System.out.println("接到通知可以了");
} catch (InterruptedException e) {
篇幅有限更多请见扩展链接:
http://www.mark-to-win.com/tutorial/java_6_ConceptExampleOfwaitnotifynotifyAll.html
- 上一篇: Java8新特性之方法引用中的双冒号
- 下一篇: Java 巧用占位符(java输出占位符变量)
猜你喜欢
- 2025-06-19 C# 客户端程序 Visual Studio 远程调试方法
- 2025-06-19 远程调试设备如何实现?有什么好处?
- 2025-06-19 AMP平台教程丨西门子PLC远程监控调试
- 2025-06-19 idea远程调试(idea远程调试docker中服务)
- 2025-06-19 那些Java架构师必知必会的技术(java架构师视频教程)
- 2025-06-19 Zookeeper使用介绍与集群搭建实战
- 2025-06-19 一文搞懂基于zipkin的分布式追踪系统原理与实现
- 2025-06-19 Java开发中的区块链技术应用:让代码更“链”接未来
- 2025-06-19 好程序员Java教程分享如何系统的学习Java
- 2025-06-19 完美避坑!记一次Elasticsearch集群迁移架构实战
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)