概述
在使用synchronized进行线程同步中介绍了依赖对象锁定线程,本篇文章介绍如何依赖对象协调线程。
同synchronized悲观锁一样,线程本身不能等待与唤醒,也是需要对象才能完成等待与唤醒的操作。
本篇主题是Object等待与唤醒。
1.在Object上有定义了以下几个方法:
- public final native void notify();
唤醒等待在此对象上的线程,如果有个线程等待,随机唤醒一个线程
- public final native void notifyAll();
唤醒等待此对象上的所有线程
- public final void wait() ;
让当前运行线程等待
- public final native void wait(long timeout);
让当前线运行程等待timeout毫,直到其他线程调用notify()方法或notifyAll()方法的对象,或一个指定的时间已经过去
- public final void wait(long timeout, int nanos);
让当前运行线程等待timeout++毫秒,直到其他线程调用notify()方法或notifyAll()方法的对象,或一个指定的时间已经过去
2.代码示例
package wang.conge.javasedemo.core.thread; import java.util.Date; public class WaitAndNotifyDemo{ public static void main(String[] args){ Object mike = new Object(); new Thread(new TalkRunable("haoran_10", mike)).start(); new Thread(new TalkRunable("conge", mike)).start(); new Thread(new TalkRunable("haoran", mike)).start(); } static class TalkRunable implements Runnable{ private String name; private Object mike; public TalkRunable(String name , Object mike){ this.name = name; this.mike = mike; } @Override public void run() { while(true){ synchronized (mike) { System.out.println(name + (new Date())); mike.notifyAll(); try { mike.wait(); } catch (InterruptedException e) { e.printStackTrace(); } } } } } }
3.流程分析
- 讲话线程。每个线程有一个名称,通过初始化赋予
- 该线程讲话前,要先拿到mike锁
- 拿到mike锁之后,讲一句话
- 唤醒等mike锁的所有线程,执行mike.notifyAll()
- 让出当前mike锁,等待其他持有mike锁的线程唤醒
4.总结
- 在执行对象的唤醒之前,首先要获得该对象的锁。想象一下,我说我把mike让出去,我都没有mike,我怎么让出去?
- 线程本身不能协调,要通过共同持有的对象去协调唤醒或者等待
- 一个对象可以协调的线程,都是该对象参与的线程。
- 对比一下,一个对象是一个人,这个做的事情是线程,那么是这个人协调这些事情,而不是这些事情协调这个人。这个人也只能协调他做的事情,他没有参与的事情,跟他毛关系也没有。
- 这也解释了为什么notify(), wait()等函数定义在Object中,而不是Thread中。协调线程的是对象,不是线程本身,由对象持有锁,并且由对象协调线程唤醒与等待操作。
相关推荐
第一个线程:遍历1–1000所有的数字,在遍历过程中,如果发现这个数字能同时被2,3,5,7整除,立即wait()等待,让第二个线程进入。 第二个线程:运行后,将一个计数器 + 1,之后再唤醒等待的线程。 主线程中:休息2秒...
多线程,线程通信,线程池和Lambda表达式 1. 多线程 1.1 线程状态 WAITING(无限等待) 当某一个线程被执行wait()方法,需要等待另外的一个线程进行唤醒操作。 一下三个方法都是Object类内的方法: public void wait()...
ReentrantLock类可以唤醒指定条件的线程,而object的唤醒是随机的 Condition类和Object类 Condition类的awiat方法和Object类的wait方法等效 Condition类的signal方法和Object类的notify方法等效 Condition类...
(3)还有一种常见的情况是该线程在 sleep,等待 sleep 的时间到了,将被唤醒。 waiting for monitor entry 或 in Object.wait() Moniter 是Java中用以实现线程之间的互斥与协作的主要手段,它可以看成是对象...
60、java中有几种方法可以实现一...答:多线程有两种实现方法,分别是继承Thread类与实现Runnable接口 同步的实现方面有两种,分别是synchronized,wait与notify 67、线程的基本概念、线程的基本状态以及状态之间的关系
3 boolean equals(Object obj) 判断此Object是否与指定的Object对象相等 4 void copy(Object obj) 把此Object拷贝到指定的Object对象中 5 Object clone() 克隆此Object对象 6 String toString() 把此Object...
与PC、内部网以及Internet 的连接,还提供与Windows gx/NT 的最佳集成和通信。 (4)支持嵌套中断。允许更高优先级别的中断首先得到响应,而不是等待低级别的ISR 完成。这使得 该操作系统具有嵌入式操作系统所要求的...
11.6 多线程与图形处理 340 11.7 总结 343 第12章 文件处理 344 12.1 处理文件的输入/输出 344 12.1.1 文本文件的处理 344 12.1.2 类型文件的处理 348 12.1.3 无类型文件的处理 356 12.2 TTextRec 和TFileRec结构 ...
与cgi的区别在于servlet处于服务器进程中,它通过多线程方式运行其service方法,一个实例可以服务于多个请求,并且其实例一般不会销毁,而CGI对每个请求都产生新的进程,服务完成后就销毁,所以效率上低于servlet。...
14.3 多线程 208 14.4 线程的优先级 210 14.5 线程的休眠与唤醒 211 14.6 线程让步 213 14.7 线程同步 214 14.7.1 同步块 216 14.7.2 同步化方法 219 14.7.3 生产者与消费者 221 14.7.4 多消费者 ...
与cgi的区别在于servlet处于服务器进程中,它通过多线程方式运行其service方法,一个实例可以服务于多个请求,并且其实例一般不会销毁,而CGI对每个请求都产生新的进程,服务完成后就销毁,所以效率上低于servlet。...
多线程,用什么关键字修饰同步方法?stop()和suspend()方法为何不推荐使用? 59.使用socket建立客户端与服务器的通信的过程 60.JAVA语言国际化应用,Locale类,Unicode 61.描述反射机制的作用 62.如何读写一个...
3. 一列数的规则如下: 1、1、2、3、5、8、13、21、34...... 求第30位数是多少, 用递归算法实现。 答:public class MainClass { public static void Main() { Console.WriteLine(Foo(30)); } public static ...
update() 在线程同步中,为了唤醒另一个等待的线程,使用下列方法 () [单选题] * A.sleep() B.wait() C.notify()(正确答案) D. join() Java高级程序设计测试含答案全文共40页,当前为第4页。Java提供以下哪个...
{8}多线程}{121}{chapter.8} {8.1}线程的常用属性与方法}{121}{section.8.1} {8.2}后台线程}{123}{section.8.2} {8.3}创建线程的两种方法}{123}{section.8.3} {8.4}Runnable}{123}{section.8.4} {8.5}Sleep...
25 3:ServicorTo 和 ServicorFrom 互换................................................................................................................25 2.3.3.1. 2.4.1. 如何确定垃圾 ......................
25 3:ServicorTo 和 ServicorFrom 互换................................................................................................................25 2.3.3.1. 2.4.1. 如何确定垃圾 ......................
第 3 章 配置内存 第 4 章 配置数据高速缓存 第 5 章 管理多处理器服务器 第 6 章 创建和管理用户数据库 第 7 章 装入和卸下数据库 第 8 章 分布式事务管理 第 9 章 创建和使用段 第 10 章 使用 reorg 命令 第 11 章...