网站首页 > 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-10-23 百万级高并发mongodb集群性能数十倍提升优化实践
- 2025-10-23 Java JIT 编译技术原理详解与实战优化
- 2025-10-23 亿优百倍|商品数据服务TiDB性能优化
- 2025-10-23 「Java」深入理解 @BatchSize:优化 JPA/Hibernate 批量操作性能
- 2025-10-23 使用Java分析器优化代码性能,解决OOM问题
- 2025-10-23 JVM 性能优化思路_jvm原理及性能调优面试题
- 2025-10-23 Java日志性能陷阱:从80%CPU占用到5%的优化实战
- 2025-10-23 Java循环优化:避开90%开发者都会踩的性能坑
- 2025-10-23 Java项目并发性能全方位优化指南_java并发处理方式有几种
- 2025-10-23 MySQL执行计划和性能优化_mysql执行计划详解
欢迎 你 发表评论:
- 最近发表
- 标签列表
-
- 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)

本文暂时没有评论,来添加一个吧(●'◡'●)