文档章节

Queue

全栈路
 全栈路
发布于 2017/03/16 09:14
字数 383
阅读 6
收藏 0

并发容器:这些容器的关键方法大部分都实现了线程安全的功能,却不使用同步关键字(synchronized).值得注意的是Queue接口本身定义的几个常用方法的区别,

1),add方法和offer方法的区别在于超出容量限制时前者抛出异常,后者返回false;

2),remove方法和poll方法都从队列中拿掉元素并返回,但是他们的区别在于空队列下操作前者抛出异常,而后者返回null;

3),element方法和peek方法都返回队列顶端的元素,但是不把元素从队列中删掉,区别在于前者在空队列的时候抛出异常,后者返回null。

 

阻塞队列接口:BlockingQueue.class

双端阻塞队列接口:BlockingDeque.class

阻塞队列,数组实现:ArrayBlockingQueue.class

阻塞双端队列,链表实现:LinkedBlockingDeque.class

阻塞队列,链表实现:LinkedBlockingQueue.class

阻塞队列,并且元素是Delay的子类,保证元素在达到一定时间后才可以取得到:DelayQueue.class

优先级阻塞队列:PriorityBlockingQueue.class

SynchronousQueue.class,同步队列,但是队列长度为0,生产者放入队列的操作会被阻塞,直到消费者过来取,所以这个队列根本不需要空间存放元素;

非阻塞队列:

ConcurrentLinkedDeque.class,非阻塞双端队列,链表实现

ConcurrentLinkedQueue.class,非阻塞队列,链表实现

 

转移队列:

TransferQueue.class,转移队列接口,生产者要等消费者消费的队列,生产者尝

© 著作权归作者所有

全栈路
粉丝 0
博文 28
码字总数 12207
作品 0
昌平
程序员
私信 提问
golang思考之运行速度之channel

golang channel测速程序: C语言有锁并发队列: C语言无锁并发队列: TCP: 速度: 测试暂时完成了,留下了很多问题: 1、为什么golang的channel比C语言快?如果C语言在内核态实现并发队列呢...

学习吧
2015/10/20
101
0
python多线程队列安全

这是一个经典的“生产者消费者”例子: python queue模块有三种队列: 1、python queue模块的FIFO队列先进先出。 2、LIFO类似于堆。即先进后出。 3、还有一种是优先级队列级别越低越先出来。 ...

lihuipeng
2014/10/18
0
0
有些数的素因子只有3,5,7.请设计一个算法,找出其中第k个数

public static int removeMin(Queue<Integer> q) { int min=q.peek(); for(Integer v:q) { if(min>v) min=v; } while(q.contains(min)) { q.remove(min); } return min; } public static voi......

一贱书生
2016/11/21
8
0
Linux平台上C语言实现异步队列的两种方法

Linux上目前有两种事件通知方式,一种是线程条件变量,一种是利用eventfd实现事件通知,下面介绍一下利用这两种方法实现异步队列的方法。 线程条件变量 相关函数介绍 pthreadcondinit:初始化...

frank21
2014/02/27
0
0
Python消息队列

消息中间件 --->就是消息队列 异步方式:不需要立马得到结果,需要排队 同步方式:需要实时获得数据,坚决不能排队 例子: #多进程模块multiprocessing from multiprocessing import Process...

粗粮面包
2017/12/18
0
0

没有更多内容

加载失败,请刷新页面

加载更多

4.01、Linux异常

1、无法连接虚拟设备ide1:0,因为主机上没有响应的设备 解决方法:找到“虚拟机” —— 打开“虚拟机设置” —— 单击“CD/DVD(IDE)”,右侧选中“使用ISO映像文件”,然后选中自己的镜像,重启...

静以修身2025
23分钟前
0
0
不允许有匹配 "[xX][mM][lL]" 的处理指令目标

Bug解决方案:org.xml.sax.SAXParseException; lineNumber: 1; columnNumber: 8; 不允许有匹配 "[xX][mM][lL]" 的处理指令目标 Caused by: org.xml.sax.SAXParseException; lineNumber: 1; c......

我叫小糖主
26分钟前
0
0
Mysql InnoDB 行锁和表锁介绍

mysql 的 InnoDB引擎支持行锁,与Oracle不同,mysql的行锁是通过索引加载的,即是行锁是加在索引响应的行上的,要是对应的SQL语句没有走索引,则会全表扫描,行锁则无法实现,取而代之的是表...

嘴角轻扬30
26分钟前
1
0
springboot+jpa 错误信息org.springframework.beans.factory.BeanCreationException

报错信息 org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'entityManagerFactory' defined in class path resource [org/springframework/boot/a......

冥焱
44分钟前
1
0
威胁快报|新兴挖矿团伙借助shodan作恶,非web应用安全再鸣警钟

近日,阿里云安全发现了一个使用未授权访问漏洞部署恶意Docker镜像进行挖矿的僵尸网络团伙。我们给这一团伙取名为Xulu,因为该团伙使用这个字符串作为挖矿时的用户名。 Xulu并不是第一个攻击...

迷你芊宝宝
51分钟前
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部