ArrayBlockingQueue原理分析-take方法

take方法是一种阻塞获取队列中元素的方法

它的实现原理很简单,有就删除没有就阻塞,注意这个阻塞是可以中断的,如果队列没有数据那么就加入notEmpty条件队列等待(有数据就直接取走,方法结束),如果有新的put线程添加了数据,那么put操作将会唤醒take线程,执行take操作。

public E take() throws InterruptedException { 
	final ReentrantLock lock = this.lock; 
	lock.lockInterruptibly(); 
	try { 
		while (count == 0) 
		notEmpty.await(); //如果队列为空的情况下,直接通过await方法阻塞 
		return dequeue(); 
	} finally { 
		lock.unlock(); 
	} 
}

如果队列中添加了元素,那么这个时候,会在enqueue中调用notempty.signal唤醒take线程来获得元素

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值