java多线程之并发集合(BlockingQueue)

本文深入探讨了Java并发编程中阻塞队列BlockQueue的应用,通过具体实例展示了如何使用BlockQueue进行线程间的同步通信。文章详细解释了add、offer、poll、peek、take等方法的使用场景及差异,为读者提供了丰富的代码实践案例。

简介

 

实现

package com.np.ota.test.queue;

import java.util.concurrent.BlockingQueue;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.TimeUnit;

public class BlockQueueTest {

	public static void main(String[] args) throws InterruptedException {
		BlockingQueue<String> queue = new LinkedBlockingQueue<String>(Integer.MAX_VALUE);
		//queue.add("121");
		queue.offer("122", 2, TimeUnit.SECONDS);//添加元素,添加超时时间
		
		//Retrieves and removes the head of this queue, or returns null if this queue is empty.
		System.out.println(queue.poll());//获取并删除,不阻塞
		//Retrieves, but does not remove, the head of this queue, or returns null if this queue is empty.
		System.out.println(queue.peek());//获取不删除,不阻塞
		//Retrieves and removes the head of this queue, waiting if necessary until an element becomes available.
		System.out.println(queue.take());//获取并删除,阻塞
	}

}

结果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值