java队列 同步_JUC-队列Queue-同步队列入门

本文介绍了SynchronousQueue,一个特殊的BlockingQueue,它不存储元素,每次put必须有对应的take操作。在示例中,两个线程分别进行put和take操作,展示了其同步特性。通过示例代码,读者可以更好地理解SynchronousQueue的工作原理。
摘要由CSDN通过智能技术生成

/**

@Author: CYW

@Date: 2020/11/19 22:41

SynchronousQueue:同步队列

继承于BlockingQueue,和其他的队列不同,它不存储元素,put进一个值就必须取出来才能再次put

*/

public class SynchronousQueueTest {

public static void main(String[] args) {

BlockingQueue blockingQueue = new SynchronousQueue<>();

new Thread(()->{

try {

System.out.println(Thread.currentThread().getName()+"put 1");

blockingQueue.put("1");

System.out.println(Thread.currentThread().getName()+"put 2");

blockingQueue.put("2");

System.out.println(Thread.currentThread().getName()+"put 3");

blockingQueue.put("3");

} catch (InterruptedException e) {

e.printStackTrace();

}

},"线程(put存)").start();

new Thread(()->{

try {

TimeUnit.SECONDS.sleep(1);

System.out.println(Thread.currentThread().getName()+blockingQueue.take());

TimeUnit.SECONDS.sleep(1);

System.out.println(Thread.currentThread().getName()+blockingQueue.take());

TimeUnit.SECONDS.sleep(1);

System.out.println(Thread.currentThread().getName()+blockingQueue.take());

} catch (InterruptedException e) {

e.printStackTrace();

}

},"线程(take取)").start();

}

}

本文地址:https://blog.csdn.net/weixin_44219219/article/details/109829643

希望与广大网友互动??

点此进行留言吧!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值