阻塞消息队列LinkedBlockingQueue主要方法
来源:互联网 发布:医学数据分析是搞什么 编辑:程序博客网 时间:2024/05/29 19:44
BlockingQueue的核心方法:
放入数据:
offer(anObject):表示如果可能的话,将anObject加到BlockingQueue里,即如果BlockingQueue可以容纳,
则返回true,否则返回false.(本方法不阻塞当前执行方法的线程)
offer(E o, long timeout, TimeUnit unit),可以设定等待的时间,如果在指定的时间内,还不能往队列中
加入BlockingQueue,则返回失败。
put(anObject):把anObject加到BlockingQueue里,如果BlockQueue没有空间,则调用此方法的线程被阻断
直到BlockingQueue里面有空间再继续.
获取数据:
poll(time):取走BlockingQueue里排在首位的对象,若不能立即取出,则可以等time参数规定的时间,
取不到时返回null;
poll(long timeout, TimeUnit unit):从BlockingQueue取出一个队首的对象,如果在指定时间内,
队列一旦有数据可取,则立即返回队列中的数据。否则知道时间超时还没有数据可取,返回失败。
take():取走BlockingQueue里排在首位的对象,若BlockingQueue为空,阻断进入等待状态直到
BlockingQueue有新的数据被加入;
drainTo():一次性从BlockingQueue获取所有可用的数据对象(还可以指定获取数据的个数),
通过该方法,可以提升获取数据效率;不需要多次分批加锁或释放锁。
- 阻塞消息队列LinkedBlockingQueue主要方法
- JDK源码分析之主要阻塞队列实现类LinkedBlockingQueue
- 阻塞队列 BlockingQueue LinkedBlockingQueue
- 阻塞队列--LinkedBlockingQueue
- 阻塞队列LinkedBlockingQueue用法
- 阻塞队列--LinkedBlockingQueue
- 链阻塞队列 LinkedBlockingQueue
- 阻塞队列之LinkedBlockingQueue
- 四 : LinkedBlockingQueue 链阻塞队列
- linkedBlockingQueue实现事件阻塞队列
- 阻塞队列LinkedBlockingQueue源码分析
- 阻塞队列LinkedBlockingQueue源码分析
- 并发队列ConcurrentLinkedQueue和阻塞队列LinkedBlockingQueue
- 并发队列ConcurrentLinkedQueue和阻塞队列LinkedBlockingQueue
- 基于LinkedBlockingQueue源码自我实现阻塞队列
- 阻塞队列--线程安全的LinkedBlockingQueue
- java-并发集合-阻塞队列 LinkedBlockingQueue 演示
- JAVA阻塞队列LinkedBlockingQueue以及非阻塞队列ConcurrentLinkedQueue区别
- js的常用方法总结(一)
- Nodejs管理工具PM2问题记录
- Android TextView和Button的使用方法
- 测试
- Python基础篇之__cmp__
- 阻塞消息队列LinkedBlockingQueue主要方法
- k8s 与 grpc
- mybatis+easyUI实现分页
- 基于JavaMail的Java邮件发送:简单邮件发送
- Thinking in Java:第六章-访问控制权限
- VTK:读取raw图片格式进行体绘制
- linux c下,从路径名中分离文件名
- 在JS写的HTML标签当中无法传递对象,或者是数组
- 2017.12.15笔记