java多线程:循环输出ABC
2016-06-13 21:53
393 查看
java多线程的经典问题:
问题:有A,B,C三个线程, A线程输出A, B线程输出B, C线程输出C,要求, 同时启动三个线程, 按顺序输出ABC, 循环10次。
首先写出测试类
其中a、b、c分别表示三个线程所对应的对象。
再写出实现Runnable接口的类
结果; ABCABCABCABCABCABCABCABCABCABC
结果分析:有三个对象 a b c
1. 首先是在线程1 在执行结束后,由于执行了a.notify(),唤醒了线程2,再由于执行了c.wait(),使得线程1
处于等待,所以while只执行了一次,需要等待有人唤醒了c,才能继续执行。
2.然后由于是线程2被唤醒了,执行了b.notify(),唤醒了线程3,再由于执行了a.wait(),使得线程2
处于等待,所以while只执行了一次,需要等待有人唤醒了a,才能继续执行。
3..然后由于是线程3被唤醒了,执行了c.notify(),唤醒了线程1,再由于执行了b.wait(),使得线程3
处于等待,所以while只执行了一次,需要等待有人唤醒了b,才能继续执行。
需要注意的是:虽然在线程1中,执行了c.wait(),但却使得线程1处于等待的状态,并且由于wait释放了对象锁,使得在线程3中,能够获得c的对象锁(语句:synchronized(now))。
问题:有A,B,C三个线程, A线程输出A, B线程输出B, C线程输出C,要求, 同时启动三个线程, 按顺序输出ABC, 循环10次。
首先写出测试类
public class Main { public static void main(String[] args) throws Exception{ Object a=new Object(); Object b=new Object(); Object c=new Object(); Mythread my1=new Mythread("A",c,a); Mythread my2=new Mythread("B",a,b); Mythread my3=new Mythread("C",b,c); Thread thread1=new Thread(my1); Thread thread2=new Thread(my2); Thread thread3=new Thread(my3); thread1.start(); Thread.sleep(1000); thread2.start(); Thread.sleep(1000); thread3.start(); Thread.sleep(1000); } }
其中a、b、c分别表示三个线程所对应的对象。
再写出实现Runnable接口的类
public class Mythread implements Runnable{ private String name=""; private Object pre;//用来表示上一个对象 private Object now;//用来表示此次对象 public Mythread(String name,Object pre,Object now){ this.name=name; this.pre=pre; this.now=now; } @Override public void run(){ int count=10; while(count>0){ count--; synchronized(pre){ synchronized(now){ System.out.println(name); now.notify();//唤醒下一个线程 } try { pre.wait(); } catch (InterruptedException e) { e.printStackTrace(); } } } } }
结果; ABCABCABCABCABCABCABCABCABCABC
结果分析:有三个对象 a b c
1. 首先是在线程1 在执行结束后,由于执行了a.notify(),唤醒了线程2,再由于执行了c.wait(),使得线程1
处于等待,所以while只执行了一次,需要等待有人唤醒了c,才能继续执行。
2.然后由于是线程2被唤醒了,执行了b.notify(),唤醒了线程3,再由于执行了a.wait(),使得线程2
处于等待,所以while只执行了一次,需要等待有人唤醒了a,才能继续执行。
3..然后由于是线程3被唤醒了,执行了c.notify(),唤醒了线程1,再由于执行了b.wait(),使得线程3
处于等待,所以while只执行了一次,需要等待有人唤醒了b,才能继续执行。
需要注意的是:虽然在线程1中,执行了c.wait(),但却使得线程1处于等待的状态,并且由于wait释放了对象锁,使得在线程3中,能够获得c的对象锁(语句:synchronized(now))。
相关文章推荐
- Python3写爬虫(四)多线程实现数据爬取
- C#实现多线程的同步方法实例分析
- 浅谈chuck-lua中的多线程
- C#简单多线程同步和优先权用法实例
- C#多线程学习之(四)使用线程池进行多线程的自动管理
- C#多线程编程中的锁系统(三)
- 解析C#多线程编程中异步多线程的实现及线程池的使用
- C#多线程学习之(六)互斥对象用法实例
- 基于一个应用程序多线程误用的分析详解
- C#多线程学习之(三)生产者和消费者用法分析
- C#多线程学习之(一)多线程的相关概念分析
- C#多线程之Thread中Thread.IsAlive属性用法分析
- 分享我在工作中遇到的多线程下导致RCW无法释放的问题
- C#多线程编程之使用ReaderWriterLock类实现多用户读与单用户写同步的方法
- C#多线程传递参数及任务用法示例
- C#控制台下测试多线程的方法
- 21天学习android开发教程之SurfaceView与多线程的混搭
- Ruby 多线程的潜力和弱点分析
- C#中WPF使用多线程调用窗体组件的方法
- C#如何对多线程、多任务管理(demo)