java 数据类型:集合接口Collection之队列Queue:PriorityQueue ;Dequeue接口和ArrayDeque实现类:
什么是Queue集合:

Queue接口定义了如下几个方法:
- void add(Object e):将制定的元素加入队列的尾部
- Object element(): 获取队列的头部元素,但不要删除改元素
- boolean offer(Object e): 将制定元素加入此队列的尾部。当使用有容量限制的队列的时候,该方法比add方法更好
- Object peek() : 获取队列头部的元素,但是不删除,如果队列为空,那么返回null
- Object remove(): 获取队列头部的元素,并删除该元素
- Object poll(): 获取并删除元素的头部的元素,如果队列为空,返回null
PriorityQueue实现类:
如何排序(同TreeSet):
- 自然排序:每个队列存放的元素都必须实现Comparable这个接口
- 定制排序,初始化PriorityQueue的时候,必须传入一个Comapator对象
import java.util.Comparator;
import java.util.PriorityQueue;
import java.util.Queue; /**
* @ClassName PriorityQueueExample
* @projectName: object1
* @author: Zhangmingda
* @description: PriorityQueue 是Queue接口的实现类,队列内的元素会有优先级之分,并不是先进先出
* date: 2021/4/10.
*/
public class PriorityQueueExample {
public static void main(String[] args) {
Queue queue = new PriorityQueue();
queue.add(3);
queue.add(33);
queue.add(32);
queue.add(-1);
queue.add(-9);
System.out.println(queue); //[-9, -1, 32, 33, 3]
Queue queue1 = new PriorityQueue((o, t1) -> (int) t1 - (int)o);
queue1.add(3);
queue1.add(33);
queue1.add(32);
queue1.add(-1);
queue1.add(-9);
System.out.println(queue1); //[33, 3, 32, -1, -9]
}
}
对象定制排序
import java.util.Comparator;
import java.util.PriorityQueue;
import java.util.Queue; /**
* @ClassName PriorityQueueExample
* @projectName: object1
* @author: Zhangmingda
* @description: PriorityQueue 是Queue接口的实现类,队列内的元素会有优先级之分,并不是先进先出
* date: 2021/4/10.
*/
public class PriorityQueueExample {
public static void main(String[] args) {
class User implements Comparable{
int age; public User(int age) {
this.age = age;
} @Override
public int compareTo(Object o) { return this.age - ((User)o).age;
} @Override
public String toString() {
return "User{" +
"age=" + age +
'}';
}
} Queue queue2 = new PriorityQueue();
queue2.offer(new User(32));
queue2.offer(new User(12));
queue2.offer(new User(48));
queue2.offer(new User(8));
System.out.println(queue2); //[User{age=8}, User{age=12}, User{age=48}, User{age=32}]
}
}
Deque接口和ArrayDeque实现类:
- 添加元素可以选择从前或后都可
- void addFirst(Object o):将指定的元素插入到双端队列的开头
- void addLast(Object o):将指定的元素插入该双端队列的末尾
- boolan offerFirst(Object e): 将指定元素插入该双端队列的开头
- boolan offerLast(Object e): 将指定元素插入到双端队列的末尾
- Iterator descendingIterator():返回该双端队列对应的迭代器,该迭代器将以逆向顺序来迭代代码中的元素。
- Object getFirst(): 获取但不删除双端队列的第一个元素
- Object getLast(): 获取但不删除双端对垒的最后一个元素
- Object peekFirst(): 获取但不删除该双端队列的第一个元素,如果此双端队列为空,那么返回null
- Object peekLast(): 获取但不删除该双端队列的最后一个元素,如果此双端队列为空,那么返回null
- Object pollFirst(): 获取并删除该双端队列的第一个元素,如果双端队列为空,那么返回null
- Object pollLast():获取并删除该双端队列的最后一个元素,如果此双端队列为空,那么返回null
栈方式增删(先进后出):
- void push(Object e): 将一个元素push进该双端队列所表示的栈的栈顶。相当于addFirst()
- Object pop() 栈方法 : pop出双端队列所表示的栈的栈顶的元素。相当于removeFirst();
import java.util.ArrayDeque;
import java.util.Queue; /**
* @ClassName ArrayQueueExample
* @projectName: object1
* @author: Zhangmingda
* @description: XXX
* date: 2021/4/10.
*/
public class ArrayQueueExample {
public static void main(String[] args) {
ArrayDeque stack = new ArrayDeque();
stack.push("张三");
stack.push("李四");
stack.push("老刘");
System.out.println(stack);
System.out.println(stack.size());
int count = stack.size(); //注意:为什么不直接放到for循环里面?size()是变化的:因为for循环过程中pop后size()的值就变小了,
for(int i=0; i<count; i++){
String s = (String)stack.pop();
System.out.println(s);
}
/**
* 老刘
* 李四
* 张三
*/
}
}
import java.util.ArrayDeque;
import java.util.Queue; /**
* @ClassName ArrayQueueExample
* @projectName: object1
* @author: Zhangmingda
* @description: XXX
* date: 2021/4/10.
*/
public class ArrayQueueExample {
public static void main(String[] args) {
Queue queue = new ArrayDeque();
queue.offer("张三");
queue.offer("老李");
queue.offer("老王");
int counts = queue.size();
for(int i=0; i<counts; i++){
String s = (String)queue.poll();
System.out.println(s);
}
/** 队列先进先出,后进后出
* 张三
* 老李
* 老王
*/
}
}
descendingIterator(): ArrayDeque特有逆向迭代器,逆向取对象
ArrayDeque queue2 = new ArrayDeque();
queue2.offer("张三");
queue2.offer("老李");
queue2.offer("老王");
Iterator iterator = queue2.descendingIterator(); //ArrayDeque特有逆向迭代器
while (iterator.hasNext()){
System.out.println(iterator.next());
}
/** ArrayDeque特有逆向迭代器,逆向取对象
* 老王
* 老李
* 张三
*/
LinkedList:
- LinkedList是同时实现List接口和Deque接口的实现类,因此LinkedList可以被当做栈和队列来使用。
- 底层数据结构是双向链表,访问慢、添加删除效率高
java 数据类型:集合接口Collection之队列Queue:PriorityQueue ;Dequeue接口和ArrayDeque实现类:的更多相关文章
- Java:集合,Collection接口框架图
Java集合大致可分为Set.List和Map三种体系,其中Set代表无序.不可重复的集合:List代表有序.重复的集合:而Map则代表具有映射关系的集合.Java 5之后,增加了Queue体系集合, ...
- Java自学-集合框架 Collection
Java集合框架 Collection Collection是一个接口 步骤 1 : Collection Collection是 Set List Queue和 Deque的接口 Queue: 先进 ...
- [Java复习] 集合框架 Collection
Q1 Collection java的集合以及集合之间的继承关系? 数组和链表的区别? 固定长度,连续内存,不能扩展,随机访问快,插入删除慢.链表相反 List, Set, Map的区别? List, ...
- java学习——集合框架(Collection,List,Set)
集合类的由来: 对象用于封装特有数据,对象多了需要存储,如果对象的个数不确定,就使用集合容器进行存储. 集合特点:1,用于存储对象的容器.2,集合的长度是可变的.3,集合中不可以存储基本数据类型值. ...
- 【Java】集合概述Collection、Map
Java集合分为Collection和Map,Collection又分为List.Set. List中有ArrayList.LinkedList和Vector:Set中又分为HashSet和TreeS ...
- Java多线程总结之线程安全队列Queue
在Java多线程应用中,队列的使用率很高,多数生产消费模型的首选数据结构就是队列.Java提供的线程安全的Queue可以分为阻塞队列和非阻塞队列,其中阻塞队列的典型例子是BlockingQueue,非 ...
- 【java】Java多线程总结之线程安全队列Queue【转载】
原文地址:https://www.cnblogs.com/java-jun-world2099/articles/10165949.html ============================= ...
- Java数据结构与算法(4) - ch04队列(Queue和PriorityQ)
队列: 先进先出(FIFO). 优先级队列: 在优先级队列中,数据项按照关键字的值有序,关键字最小的数据项总在对头,数据项插入的时候会按照顺序插入到合适的位置以确保队列的顺序,从后往前将小于插入项的数 ...
- Java精选笔记_集合概述(Collection接口、Collections工具类、Arrays工具类)
集合概述 集合有时又称为容器,简单地说,它是一个对象,能将具有相同性质的多个元素汇聚成一个整体.集合被用于存储.获取.操纵和传输聚合的数据. 使用集合的技巧 看到Array就是数组结构,有角标,查询速 ...
随机推荐
- CreateProcess error=206, 文件名或扩展名太长。
改:
- SpringCloud升级之路2020.0.x版-44.避免链路信息丢失做的设计(1)
本系列代码地址:https://github.com/JoJoTec/spring-cloud-parent 我们在这一节首先分析下 Spring Cloud Gateway 一些其他可能丢失链路信息 ...
- Identity Server 4 从入门到落地(二)—— 理解授权码模式
Identity Server 的目的是认证和授权,我们需要理解认证和授权的工作过程.这就需要了解OAuth 2.0的四种授权模式,下面这张图是授权码模式的工作过程,至少我在一开始看得一头雾水: 现在 ...
- 带你了解Typescript的14个基础语法
摘要:Typescript可以说是JavaScript的超集,在JS的基础上新增了许多语法特性,使得类型不再可以随意转换,能大大减少开发阶段的错误. 本文分享自华为云社区<Typescript基 ...
- CF1539F Strange Array
这玩意为啥是紫. 考虑对每个小于\(x\)的数值设为1,大于\(x\)的数值设为-1. 那么对于答案要求的就是绝对值最大的连续段. 线段树是很显然的. 考虑我们不能对每个数都进行一遍重构,这样就退化到 ...
- Codeforces 1303G - Sum of Prefix Sums(李超线段树+点分治)
Codeforces 题面传送门 & 洛谷题面传送门 个人感觉这题称不上毒瘤. 首先看到选一条路径之类的字眼可以轻松想到点分治,也就是我们每次取原树的重心 \(r\) 并将路径分为经过重心和不 ...
- Perl调用和管理外部文件中的变量(如软件和数据库配置文件)
编写流程时,有一个好的习惯是将流程需要调用的软件.数据库等信息与脚本进行分离,这样可以统一管理流程的软件和数据库等信息,当它们路径改变或者升级的时候管理起来就很方便,而不需要去脚本中一个个寻找再修改. ...
- 用JS实现方块碰撞
首先我们应用上次的内容--方块拖拽,利用方块拖拽来让两个方块进行碰撞. 我们可以先定义两个正方形方块,红色的div1,绿色的div2,我们来实现当div1碰撞div2时div2的颜色变为黄色 HTML ...
- javascript的事件循环机制
JavaScript是一门编程语言,既然是编程语言那么就会有执行时的逻辑先后顺序,那么对于JavaScript来说这额顺序是怎样的呢? 首先我们我们需要明确一点,JavaScript是单线程语言.所谓 ...
- [学习总结]1、View的scrollTo 和 scrollBy 方法使用说明和区别
参考资料:http://blog.csdn.net/vipzjyno1/article/details/24577023 非常感谢这个兄弟! 先查看这2个方法的源码: scrollTo: 1 /** ...