经典线程处理打印ABC问题分析

package com;

public class MyThreadPrinter2 implements Runnable {

 private String name;
 private Object prev;
 private Object self;

 private MyThreadPrinter2() {

 }

 private MyThreadPrinter2(String name, Object prev, Object self) {
  this.name = name;
  this.prev = prev;
  this.self = self;
 }

 @Override
 public void run() {
  int count = 10;
  while (count > 0) {
   synchronized (prev) {
    synchronized (self) {
     System.out.print(name);
     count--;

     self.notify();
    }
    try {
     prev.wait();
    } catch (InterruptedException e) {
     e.printStackTrace();
    }
   }

  }
 }

 public static void main(String[] args) throws Exception {
  Object a = new Object();
  Object b = new Object();
  Object c = new Object();
  MyThreadPrinter2 pa = new MyThreadPrinter2("A", c, a);
  MyThreadPrinter2 pb = new MyThreadPrinter2("B", a, b);
  MyThreadPrinter2 pc = new MyThreadPrinter2("C", b, c);

  new Thread(pa).start();
  new Thread(pb).start();
  new Thread(pc).start();
 }
}
/*
 *
 *
 * 思路分析:
 * 该问题为三个线程间的同步唤醒操作,主要的目的就是ThreadA->TthreadB->ThreadC->ThreadA循环执行单个线程.
 * 为了控制线程执行的顺序
 * 就必须确定唤醒,等待的顺序,所以每一个线程必须同时持有两个对象锁,才能继续执行,
 * 一个对象锁是prev,就是前一个线程所持有的对象锁.还有一个就是自身对象锁,
 * 主要的思想就是,为了控制执行的顺序,必须先持有prev锁,也就是前一个线程要释放自身
 * 的对象锁,再去申请自身的对象锁,两者兼备是打印,之后首先调用self.notify()释放自身对象锁,
 * 唤醒下一个线程等待,在调用prev.wait()释放prev对象锁,终止当前进程,等待循环结束再次被唤醒
 *
 *
 *
*/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值