java里面的队列
非阻塞无界队列
ConcurrentLinkedQueue
public static void main(String[] args) throws InterruptedException {
ConcurrentLinkedQueue queue=new ConcurrentLinkedQueue();
queue.add(1);//内部调用offer
queue.offer(1);
queue.remove();//如果队里为空会报java.util.NoSuchElementException
queue.peek();//拿队列元素 但不删除
queue.poll();获取队列元素并删除如果没有则是null
}
阻塞队列
阻塞队列 指的是像队列添加元素 如果满了则阻塞等待队列容器有空间再往里面添加元素。或则 队列为空往容器里面取元素 则阻塞等待队列里面有元素取出‘
方法。
JDK7提供了7个阻塞队列
- ArrayBlockingQueue :一个由数组结构组成的有界阻塞队列。
- LinkedBlockingQueue :一个由链表结构组成的有界阻塞队列。
- PriorityBlockingQueue :一个支持优先级排序的无界阻塞队列。
- DelayQueue:支持延时的队列
- SynchronousQueue:一个不存储元素的阻塞队列。
- LinkedTransferQueue:一个由链表结构组成的无界阻塞队列。
- LinkedBlockingDeque:一个由链表结构组成的双向阻塞队列。
常用方法
添加
boolean add 如果队列满了add则抛出异常
boolean offer 如果队列满了 可以设置阻塞时间
void put 如果队列满了则一直阻塞
获取队列元素并移除
Integer remove 如果队列为空 则抛出异常
Integer poll 如果队列为空可设置阻塞时间
void take 如果队列为空 一直阻塞
获取队列元素不移除
element 如果队列为空抛出异常
peek 如果队列为空则获的null
ArrayBlockingQueue
使用数组实现 先进先出的队列。提供2个构造参数,默认不保证访问者公平的访问队列,就是调用添加方法 默认不是按先阻塞的线程 先存。 或者移除 不是按先阻塞的线程先获取并移除 可以通过ArrayBlockingQueue fairQueue =
new
ArrayBlockingQueue(
1000
,
true
); 设置为true保证公平性
LinkedBlockingQueue
使用链表实现 跟ArrayBolckingQueue的区别则是
ArrayBolckingQueue:
1.一个是生产者和消费者使用的是同一把锁。
2.初始化必须指定大小
3.插入时直接将对象插入
LinkedBlockingQueue:
1.则是使用生产者使用一把锁 消费者使用一把锁
2.可以不指定容器大小 但是最大值是Integer.MAX_VALUE
3.插入时将对象转为Node插入
PriorityBlockingQueue
拥有优先级排序的无界队列。需要实现comparator接口。
public class Student implements Comparable<Student> {
public Integer age;
public Student(Integer age){
this.age=age;
}
@Override
public int compareTo(Student stu) {
if(age < stu.age)
{
return -1;
}else
{
if(age > stu.age)
{
return 1;
}else
{
return 0;
}
}
}
}
PriorityBlockingQueue<Student> queue=new PriorityBlockingQueue<Student>();
queue.add(new Student(1));
queue.add(new Student(3));
queue.add(new Student(5));
queue.add(new Student(0));
System.out.println(queue.poll().age);
System.out.println(queue.poll().age);
System.out.println(queue.poll().age);
System.out.println(queue.poll().age);
输出
0
1
3
5
DelayQueue
支持延时的无界阻塞队列 需要实现delay接口
public class Message implements Delayed {
private final long expire; //到期时间
private final String msg; //数据 public Message( long expire, String msg) {
this.expire = expire;
this.msg = msg;
} /**
* 需要实现的接口,获得延迟时间 用过期时间-当前时间
* @param unit
* @return
*/
@Override
public long getDelay(TimeUnit unit) {
return unit.convert(this.expire - System.currentTimeMillis() , TimeUnit.MILLISECONDS);
} @Override
public int compareTo(Delayed other) {
return (int) (this.getDelay(TimeUnit.MILLISECONDS) -other.getDelay(TimeUnit.MILLISECONDS));
} public long getExpire() {
return expire;
} public String getMsg() {
return msg;
}
}
public static void main(String[] args) throws InterruptedException {
DelayQueue<Message> queue=new DelayQueue<Message>(); Calendar nowTime = Calendar.getInstance();
nowTime.add(Calendar.MINUTE, 1);
Message message=new Message(nowTime.getTime().getTime(),"哈哈哈");
queue.add(message);
nowTime = Calendar.getInstance();
nowTime.add(Calendar.MINUTE, 3);
message=new Message(nowTime.getTime().getTime(),"哈哈哈3");
queue.add(message);
nowTime = Calendar.getInstance();
nowTime.add(Calendar.MINUTE, 2);
message=new Message(nowTime.getTime().getTime(),"哈哈哈2");
queue.add(message);
while (true) {
Message message1= queue.take();
System.out.println(message1.getMsg());
}
}
SynchronousQueue
没有容量的队列。生产者生产立即推送给消费者
public static void main(String[] args) throws InterruptedException {
SynchronousQueue<String> queue=new SynchronousQueue<String>();
new Thread(new Runnable() {
@Override
public void run() {
int i=0;
while (true){
try {
Thread.sleep(1000);
queue.put(Integer.toString(i));
} catch (Exception e) {
e.printStackTrace();
}
i++;
}
}
}).start();
new Thread(new Runnable() { @Override
public void run() {
while (true){
try {
Thread.sleep(2000);
System.out.println(queue.take().toString());
} catch (Exception e) {
e.printStackTrace();
} { }
} }
}).start();
}
LinkedTransferQueue
LinkedTransferQueue是一个由链表结构组成的无界阻塞TransferQueue队列。相对于其他阻塞队列LinkedTransferQueue多了tryTransfer和transfer方法。
1. transfer(E e):若当前存在一个正在等待获取的消费者线程,即立刻移交之;否则,会插入当前元素e到队列尾部,并且等待进入阻塞状态,到有消费者线程取走该元素。
2. tryTransfer(E e):若当前存在一个正在等待获取的消费者线程(使用take()或者poll()函数),使用该方法会即刻转移/传输对象元素e;若不存在,则返回false,并且不进入队列。这是一个不阻塞的操作。
LinkedBlockingDeque
LinkedBlockingDeque是一个由链表结构组成的双向阻塞队列。所谓双向队列指的你可以从队列的两端插入和移出元素。双端队列因为多了一个操作队列的入口,在多线程同时入队时,也就减少了一半的竞争。相比其他的阻塞队列,LinkedBlockingDeque多了addFirst,addLast,offerFirst,offerLast,peekFirst,peekLast等方法
java里面的队列的更多相关文章
- Java多线程 阻塞队列和并发集合
转载:大关的博客 Java多线程 阻塞队列和并发集合 本章主要探讨在多线程程序中与集合相关的内容.在多线程程序中,如果使用普通集合往往会造成数据错误,甚至造成程序崩溃.Java为多线程专门提供了特有的 ...
- Java 中的队列 Queue
一.队列的定义 我们都知道队列(Queue)是一种先进先出(FIFO)的数据结构,Java中定义了java.util.Queue接口用来表示队列.Java中的Queue与List.Set属于同一个级别 ...
- java实现链队列
java实现链队列的类代码: package linkqueue; public class LinkQueue { class Element { Object elem; Element next ...
- Java服务器端消息队列实战
服务端口监听--报文接收--报文解码--业务处理--报文编码--写回客户端 从服务端与客户端成功握手并产生一个socket后,为了提高吞吐能力,接下来的事情就可以交给多线程去处理. 为了对接入的请求做 ...
- 使用goroutine+channel和java多线程+queue队列的方式开发各有什么优缺点?
我感觉很多项目使用java或者c的多线程库+线程安全的queue数据结构基本上可以实现goroutine+channel开发能达到的需求,所以请问一下为什么说golang更适合并发服务端的开发呢?使用 ...
- java中有界队列的饱和策略(reject policy)
文章目录 AbortPolicy DiscardPolicy DiscardOldestPolicy CallerRunsPolicy 使用Semaphore java中有界队列的饱和策略(rejec ...
- Java集合--阻塞队列及各种实现的解析
阻塞队列(Blocking Queue) 一.队列的定义 说的阻塞队列,就先了解下什么是队列,队列也是一种特殊的线性表结构,在线性表的基础上加了一条限制:那就是一端入队列,一端出队列,且需要遵循FIF ...
- Java:阻塞队列
Java:阻塞队列 本笔记是根据bilibili上 尚硅谷 的课程 Java大厂面试题第二季 而做的笔记 1. 概述 概念 队列 队列就可以想成是一个数组,从一头进入,一头出去,排队买饭 阻塞队列 B ...
- java代码实现队列的优化
package com.voole.queun; /** * @Decription 队列 * @author TMAC-J * */ public class Queun { /** * 初始化队列 ...
- Java数据结构之队列的实现以及队列的应用之----简单生产者消费者应用
Java数据结构之---Queue队列 队列(简称作队,Queue)也是一种特殊的线性表,队列的数据元素以及数据元素间的逻辑关系和线性表完全相同,其差别是线性表允许在任意位置插入和删除,而队列只允许在 ...
随机推荐
- codeforces 898F Hash
F. Restoring the Expression time limit per test 2 seconds memory limit per test 256 megabytes input ...
- B3300 [USACO2011 Feb]Best Parenthesis 模拟
这是我今天遇到最奇怪的问题,希望有人帮我解释一下... 一开始我能得90分: #include<iostream> #include<cstdio> #include<c ...
- hdu5673-Robot
题目: http://acm.hdu.edu.cn/showproblem.php?pid=5673 好久没打BC,当时这场过了3题,hack了一个,马马虎虎吧,因为前三个题确实不难. 这个是那场的第 ...
- HTML 13 常用构造函数( 类 )
Number * Data ** String **** Array ***** Math **** RegExp *****
- BZOJ 1975 k短路 A*
思路: 直接上A* //By SiriusRen #include <queue> #include <cstdio> #include <cstring> #in ...
- BZOJ 2969 期望
思路: 我们可以分开算每个格子自己的期望啊... 期望可以累加的 那就把这个大格子 分成 9个部分 分别算好了... //By SiriusRen #include <cmath> #in ...
- C - Domino piling
Problem description You are given a rectangular board of M × N squares. Also you are given an unlimi ...
- python--3、函数
定义: 定义函数时,也相当于定义变量.会把函数体内的代码存入开辟的内存空间中.使用函数时,通过func() 声明是函数,其对应的值为代码.函数是指将一组语句的集合通过一个名字(函数名)封装起来,要想执 ...
- java编程基础篇-------> 从键盘输入一位整数,代表月份,编程判断指定月份属于一年中的哪个季度。如果是 12 月、1 月、2 月,就属于冬季。
从键盘输入一位整数,代表月份,编程判断指定月份属于一年中的哪个季度.如果是 12月.1 月.2 月,就属于冬季:如果是 3 月.4 月.5 月,就属于春季:如果是 6 月.7 月.8 月,就属于夏季: ...
- spring - quartz - experssion 表达式
字段 允许值 允许的特殊字符 秒 0-59 , - * / 分 0-59 , - * / 小时 0-23 , - * / 日期 1-31 , - * ? / L W C 月份 1-12 或者 JAN- ...