阿里面试题-使用三个线程循环有序打印A、B、C怎么实现?

阿里面试题-使用三个线程循环有序打印A、B、C怎么实现?

  面试的时候,脑子比较蒙,当时这道题也没有答出来。事后思考了一下,暂时能想到四种解决方法。

1.使用Object.wait()/notify()方式

  使用wait\notify方法,其实也就是前一个线程A打印完成后使用notify唤醒下一个处于等待状态的线程B打印,然后B和C,C和A也是一样

  需要注意的是处于等待态的线程可能会被假唤醒,这时java和操作系统所允许的行为,所以在线程被唤醒后,我们需要检查保护条件是否成立,如果不成立则继续调用wait()方法。

  完整代码如下:
Condition.java

package mianshi_code;

import java.util.concurrent.atomic.AtomicInteger;

public class Condition {
   
    AtomicInteger cnt = new AtomicInteger(0);
    final int limit ;
    public Condition(int printCnt){
   
        limit = printCnt ;
    }
    public void next(){
    cnt.getAndIncrement();}
    public int get(){
   return cnt.get();}
    public boolean stop(){
   
        return cnt.get() >= limit ;
    };
}

Mission.java

package mianshi_code;
public interface Mission{
   
    void doJob();
};

CirculatePrint.java

package mianshi_code;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicBoolean;

public class CirculatePrint {
   
    static class ProtectedCondition{
   
        AtomicBoolean state ;
        public ProtectedCondition(boolean initVal){
   
            state = new AtomicBoolean(initVal);
        }

        public ProtectedCondition(){
   
            state = new AtomicBoolean(false);
        }

        public boolean succeed(){
   
            return state.get();
        }

        public void change(boolean x){
   
            state.set(x);
        }
    }

    static class WorkThread implements Runnable{
   
        final Object waiting ;
        final Object notify ;
        String content ;
        Condition condition ;
        ProtectedCondition proCond ;
        ProtectedCondition nextCond ;
        public WorkThread(Object a , Object b , String printContent , Condition cond , ProtectedCondition proCon , ProtectedCondition nxtCon)
        {
   
            waiting = a ;
            notify = b;
            content = printContent ;
            condition = cond ;
            proCond = proCon ;
            nextCond = nxtCon;
        }

        @Override
        
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值