偶遇一个生产者消费者面试题

题目:

编写程序实现一个掷骰子的过程,

线程a负责掷骰子,每次掷一个骰子,
线程b负责把每次骰子的数字都输出到屏幕上

如果骰子是连续的3个6,则线程a与线程b都退出

对于这个题目我用的是最老的方法,wait/notifyAll 等待通知 来做的。这题考的是多线程中的生产者消费者模式。

什么也不说了,直接上代码

    public static void main(String[] args) {
//创建一个临界资源o
Object o = new Object();
//创建一个Integer集合,每次掷出来的骰子都存放在这个集合里。
List<Integer> list = new ArrayList<Integer>(); 
//创建A线程
Thread t1 = new Thread(new Runnable() {
@Override
public void run() {
//对o这个临界资源加锁
synchronized (o) {
//因为不知道要掷多少次骰子,才能达到标准,所以使用while(true)
while(true) {
//唤醒所有等待的线程,让等待的线程进入就绪状态
o.notifyAll();
//设置随机数
Random rd = new Random();
a = rd.nextInt(6)+1;
//打印a线程生成的随机数
System.out.println("a"+a);
//把随机数添加到集合中
list.add(a);
try {
//判断集合中的元素连续3个是否都==6
if(list.get(list.size()-1)==6&&list.get(list.size()-2)==6&&list.get(list.size()-3)==6) {
//满足则跳出
return;
}
//不满足则等待
o.wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
});

Thread t2 = new Thread(new Runnable() {

@Override
public void run() {
对o这个临界资源加锁
synchronized(o) {

while(true) {
//唤醒所有等待的线程,让等待的线程进入就绪状态
o.notifyAll();
//输出这个a
System.out.println(a);
try {
//判断是否满足条件
if(list.get(list.size()-1)==6&&list.get(list.size()-2)==6&&list.get(list.size()-3)==6) {
//满足,跳出
return;
}
//等待
o.wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
});
//启动线程
t1.start();
t2.start();
}

欢迎各路大神指导!!!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值