JAVA线程池_并发队列工作笔记0001---认识阻塞队列_非阻塞队列

 技术交流QQ群【JAVA,C++,Python,.NET,BigData,AI】:170933152

注意这个ConcurrentLinkedQueue这个是个非阻塞队列,

这个队列是没有长度限制的,不用给一个长度,直接,向队列不停的.add数据就可以,

然后poll,是出队列,出队列的同时,并且会从队列中移出元素

然后peek,会返回队列内容,但是不会移出元素,在Vc++中,还做个peekmessage

可以移出,有个参数,写上就可以移出,在vc++中没有pool这个用法

可以看到我添加了3个,pool移出一个还要size是2,然后再peek,可以看到,长度并没有变,peek不会移出元素

并且队列是先进先出,也就是java先添加的,java先读出来,然后栈是先进后出,其实队列就是平时排队,栈就是只有一个出口,跟羽毛球筒一样,

先放入进去的球最后拿出来

 

然后再看看阻塞队列

可以看到这个阻塞队列是个接口

阻塞队列是有边界的,也就是需要给他个长度,这里给他个3个长度.

这里可以看到,如果我队列长度是3,我放入了4个元素,就报错了

这个时候我们可以不用add,用offer来进行添加数据

offer添加数据的时候是这样的,

可以看到,offer先添加3个数据,因为队列的长度就是3,

然后添加第4个时候,我这样添加,offer可以看到有2个参数,3是超时时间

TimeUnit.SECONDS就是单位意思就是,我oofer尝试去添加数据,

尝试3秒还是添加不进去,就不添加了

 

执行一下可以看到没添加进去

如果我添加第4个时候,先出队一共,可以看到再去添加就添加进去了

可以看到就可以了.

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

添柴程序猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值