阻塞队列 java实现_JAVA实现阻塞队列

package 多线程并发;

import java.util.Stack;

/**

* Created by z84102272 on 2018/7/17.

*/

public class BlockQueueImpl {

private final static Object pushLock = new Object(); //push的锁

private final static Object popLock = new Object(); //pop的锁

private Stack stack; //存储数据

public BlockQueueImpl(){

stack = new Stack<>();

}

/**

* push锁

*/

private void pushLock(){

synchronized (pushLock){

try{

pushLock.wait();

}catch (Exception e){

e.printStackTrace();

}

}

}

/**

* 释放push锁

*/

private void pushUnlock(){

pushLock.notify();

}

private void popLock(){

try {

popLock.wait();

}catch (Exception e){

e.printStackTrace();

}

}

private void popUnlock(){

popLock.notify();

}

public synchronized void push(Object o){

int MAX_SIZE = 3;

if (stack.size() >= MAX_SIZE){

pushLock();

}

stack.push(o);

popUnlock();

}

public Object pop(){

if (stack.size()==0){

popLock();

}

Object o = stack.pop();

pushUnlock();

return o;

}

}

原文:https://www.cnblogs.com/zyfzyfzyf/p/9324778.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值