- 浏览: 236076 次
- 性别:
- 来自: 深圳
文章分类
最新评论
-
wahahachuang8:
GoEasy 实时推送支持IE6-IE11及大多数主流浏览器的 ...
服务器推送技术 java -
mahuanjian:
[flash=200,200][/flash]
服务器推送技术 java -
wenjundiandian:
下面有网页编辑器的话还是会被隐藏.
ext中消息框、提示框、确认框显示在最前面的解决方法 -
天塔上的猫:
/**
* JAVA常见的权限控制算法的实现
*
* ...
JAVA常见的权限控制算法的实现
- import java.util.ArrayDeque;
- import java.util.Deque;
- public class IntegerStack {
- private Deque<Integer> data = new ArrayDeque<Integer>();
- public void push(Integer element) {
- data.addFirst(element);
- }
- public Integer pop() {
- return data.removeFirst();
- }
- public Integer peek() {
- return data.peekFirst();
- }
- public String toString() {
- return data.toString();
- }
- public static void main(String[] args) {
- IntegerStack stack = new IntegerStack();
- for (int i = 0; i < 5; i++) {
- stack.push(i);
- }
- System.out.println("After pushing 5 elements: " + stack);
- int m = stack.pop();
- System.out.println("Popped element = " + m);
- System.out.println("After popping 1 element : " + stack);
- int n = stack.peek();
- System.out.println("Peeked element = " + n);
- System.out.println("After peeking 1 element : " + stack);
- }
- }
package code.jdk; import java.util.ArrayDeque; import java.util.Deque; public class IntegerStack { private Deque<Integer> data = new ArrayDeque<Integer>(); public void push(Integer element) { data.addFirst(element); } public Integer pop() { return data.removeFirst(); } public Integer peek() { return data.peekFirst(); } public String toString() { return data.toString(); } public static void main(String[] args) { IntegerStack stack = new IntegerStack(); for (int i = 0; i < 5; i++) { stack.push(i); } System.out.println("After pushing 5 elements: " + stack); int m = stack.pop(); System.out.println("Popped element = " + m); System.out.println("After popping 1 element : " + stack); int n = stack.peek(); System.out.println("Peeked element = " + n); System.out.println("After peeking 1 element : " + stack); } }
运行结果
- Popped element = 4
- After popping 1 element : [3, 2, 1, 0]
- Peeked element = 3
- After peeking 1 element : [3, 2, 1, 0]
After pushing 5 elements: [4, 3, 2, 1, 0] Popped element = 4 After popping 1 element : [3, 2, 1, 0] Peeked element = 3 After peeking 1 element : [3, 2, 1, 0]
Deque 的API说明
public interface Deque<E>extends Queue<E>一个线性 collection,支持在两端插入和移除元素。名称 deque 是“double ended queue(双端队列)”的缩写,通常读为“deck”。大多数 Deque 实现对于它们能够包含的元素数没有固定限制,但此接口既支持有容量限制的双端队列,也支持没有固定大小限制的双端队列。 此接口定义在双端队列两端访问元素的方法。提供插入、移除和检查元素的方法。每种方法都存在两种形式:一种形式在操作失败时抛出异常,另一种形式返回一个特殊值(null 或 false,具体取决于操作)。插入操作的后一种形式是专为使用有容量限制的 Deque 实现设计的;在大多数实现中,插入操作不能失败。 下表总结了上述 12 种方法:
第一个元素(头部) | 最后一个元素(尾部) | |||
抛出异常 | 特殊值 | 抛出异常 | 特殊值 | |
插入 | addFirst(e) | offerFirst(e) | addLast(e) | offerLast(e) |
移除 | removeFirst() | pollFirst() | removeLast() | pollLast() |
检查 | getFirst() | peekFirst() | getLast() | peekLast() |
此接口扩展了 Queue 接口。在将双端队列用作队列时,将得到 FIFO(先进先出)行为。将元素添加到双端队列的末尾,从双端队列的开头移除元素。从 Queue 接口继承的方法完全等效于 Deque 方法,如下表所示:
Queue 方法 | 等效 Deque 方法 |
add(e) | addLast(e) |
offer(e) | offerLast(e) |
remove() | removeFirst() |
poll() | pollFirst() |
element() | getFirst() |
peek() | peekFirst() |
双端队列也可用作 LIFO(后进先出)堆栈。应优先使用此接口而不是遗留 Stack 类。在将双端队列用作堆栈时,元素被推入双端队列的开头并从双端队列开头弹出。堆栈方法完全等效于 Deque 方法,如下表所示:
堆栈方法 | 等效 Deque 方法 |
push(e) | addFirst(e) |
pop() | removeFirst() |
peek() | peekFirst() |
注意,在将双端队列用作队列或堆栈时,peek 方法同样正常工作;无论哪种情况下,都从双端队列的开头抽取元素。 此接口提供了两种移除内部元素的方法:removeFirstOccurrence 和 removeLastOccurrence。 与 List 接口不同,此接口不支持通过索引访问元素。 虽然 Deque 实现没有严格要求禁止插入 null 元素,但建议最好这样做。建议任何事实上允许 null 元素的 Deque 实现用户最好不 要利用插入 null 的功能。这是因为各种方法会将 null 用作特殊的返回值来指示双端队列为空。 Deque 实现通常不定义基于元素的 equals 和 hashCode 方法,而是从 Object 类继承基于身份的 equals 和 hashCode 方法。 此接口是 Java Collections Framework 的成员。
来源:http://www.java2000.net/p624
发表评论
-
利用 Heritrix 构建特定站点爬虫
2011-01-12 13:42 896Heritrix 是一个由 java 开 ... -
java解析xml文件四种方式
2011-01-10 16:23 7671.介绍 1)DOM(JAXP Crims ... -
Spring AOP的两种实现方式
2010-12-10 09:16 908来源:http://javacrazyer.iteye.com ... -
详解Java解析XML的四种方法
2010-12-09 22:31 852来源:http://mengsina.iteye.co ... -
(转载)手写压缩软件,超详细解释(哈夫曼实现)
2010-12-07 11:17 1099转载自:http://stchou.iteye.com/b ... -
java通过包装器防SQL注入
2010-01-29 11:04 1252定义包装器对request进行 ... -
comparable 与comparator的区别
2010-01-29 09:12 957Comparable & Comparator 都是用 ... -
Java经典问题算法大全
2010-01-28 20:52 3042/*【程序1】题目:古典 ... -
Java各种排序算法
2010-01-28 20:50 928/*** 排序测试类* * 排序算法的分类如下:* 1.插入排 ... -
Java细节总结
2010-01-28 20:46 708TURE、FALSE、NULL等都不是Java关键字; 数组 ... -
设计异常管理系统
2010-01-28 20:37 849——针对有效的错误处理设计异常管理系统 作者:Jean-Pie ... -
使用Filter快速对网页资源进行缓存
2010-01-28 20:18 900使用Filter快速对网页资源进行缓存,在网页资源没有改变的情 ... -
详解ThreadLocal与synchronized
2010-01-28 20:14 801Java良好的支持多线程。使用java,我们可以很轻松的编程一 ... -
在有多个选择路径的情况下,利用Switch可以使程序更加简洁有效。但由于其只能对整数选择因子进行判断,所以限制了其在其他类型尤其是String的使用,本文利用J
2010-01-28 20:04 889在有多个选择路径的情况下,利用Switch可以使程序更加简洁有 ... -
java优化编程37条
2010-01-28 20:00 7131.JVM管理两种类型的内 ... -
服务器推送技术 java
2009-12-28 12:11 6291下面介绍在ARP之上的一个非常热门的技术实现:服务器推送技术。 ... -
java排序集锦
2009-12-16 09:29 856Java代码 package sort; ... -
3DES加密解密调用示例
2009-12-15 10:02 995在java中调用sun公司提供的3DES加密解密算法时,需要使 ... -
java货币 Locale Currency NumberFormat
2009-12-04 18:14 2388使用java currency配合Locale,NumberF ... -
Random类
2009-12-04 14:00 1043Random类 (java.util) ...
相关推荐
Deque(双端队列)不仅可以作为堆栈使用,还能作为队列,提供了更多的操作方法。 `Deque`接口继承自`Queue`接口,提供了在两端添加和移除元素的能力。在Java中,`ArrayDeque`是`Deque`的一个高效实现,它是无界的,...
2. `java.util.Deque`接口:提供了一种更通用的数据结构,可以作为双端队列使用,包括ArrayDeque和LinkedList的实现。ArrayDeque在性能上通常优于LinkedList,尤其在并发环境中。 3. 自定义数据结构:通过继承...
在Java中,我们可以使用ArrayDeque、LinkedList或者自定义类来实现堆栈。 【描述】: 该描述中提到的链接可能指向一篇关于堆栈算法实际应用的文章,但具体内容没有提供。通常,堆栈算法的实现涉及以下几个关键操作...
6. **效率对比**:由于其数组基础和指针操作的特性,`ArrayDeque`在作为堆栈(后进先出,LIFO)时的性能优于`Stack`,在作为队列(先进先出,FIFO)时的性能优于`LinkedList`。这是因为`LinkedList`在插入和删除元素...
但在性能要求较高的情况下,可能需要考虑使用非同步的替代品,如`Deque`接口的实现,如`ArrayDeque`。 - Stack类基于Vector实现,因此它的操作效率相对较低,因为Vector的大多数操作都有同步锁。在单线程环境中,...
不过,在性能敏感的应用中,更倾向于使用ArrayList的子类java.util.Deque,如ArrayDeque,因为它们通常提供更好的性能。 堆栈编程的核心在于利用堆栈的特性来解决问题。以下是一些典型的应用场景: 1. **递归算法*...
4. **Java实现**:Java提供了`java.util.Stack`类来实现堆栈功能,也可以使用`Deque`接口(例如`ArrayDeque`)以更高效的方式实现堆栈操作。 **队列(Queue)**: 1. **定义**:队列是一种先进先出(FIFO, First In...
另一种方法是利用`java.util.Deque`接口,特别是`ArrayDeque`类,它是一个高效的双端队列,可以作为栈使用。`ArrayDeque`相比于`Stack`在性能上更优,因为它避免了`Vector`的同步开销。 本程序的"汪秋云 MyStack....
在Java8中,`java.util.Stack`类是实现堆栈功能的一个选项,但通常推荐使用`java.util.Deque`接口的实现,如`ArrayDeque`,因为它们提供更丰富的操作和更好的性能。 学习卡片可能包含以下内容: 1. **基本概念**:...
LinkedList还实现了Deque接口,可以作为单向和双向实例。 堆栈继承自向量,提供基础的堆栈操作。其保障线程安全的手段是使用同步的包装所有函数,和其他线程安全的集合比起来,在多线程环境中效率很低。 ...
- `Queue`代表先进先出(FIFO)的数据结构,如`LinkedList`可作为队列使用。 - `Deque`(双端队列)扩展了`Queue`,允许在两端添加和移除元素,如`ArrayDeque`。 5. **Stack** - `Stack`是`Vector`的一个子类,...
队列是一种先进先出(FIFO)的数据结构,Java中可以使用LinkedList或ArrayDeque来实现。队列常用于任务调度、事件处理和多线程环境中的同步。例如,Java的Queue接口提供了offer()用于添加元素,poll()用于移除并返回...
`ArrayDeque`是一个双端队列,可以作为栈或队列使用。`PriorityQueue`则根据元素的优先级进行排序,常用于调度任务。 容器类还包含`Stack`,它是后进先出(LIFO)的数据结构,模仿了传统的堆栈。`Deque`接口扩展了`...
在Java中,虽然`java.util.Stack`类是基于Vector实现的,但通常建议使用`java.util.Deque`接口的实现,如`ArrayDeque`,来实现性能更优的顺序栈。 总之,顺序栈是数据结构的基础组成部分,理解其原理和操作方法对于...
对于栈操作,可以考虑使用`java.util.Stack`的替代品`Deque`接口的实现,如`ArrayDeque`,它在单线程环境下的性能更优。尽管如此,理解`Vector`和`Stack`的工作原理仍然对学习Java集合框架的历史和并发编程概念具有...
更好的实现方式是双端队列(deque),例如使用ArrayDeque或LinkedList。 哈希表(或称字典)提供了一种通过键(key)快速查找值(value)的数据结构。JavaScript的Object就是一种哈希表,通过键值对存储数据,查找...
以及Deque接口的实现,如ArrayDeque,它是高效的双端队列,支持在两端添加和移除元素,适用于实现堆栈、队列或双端队列。 在分析和优化容器效率时,我们需要考虑以下几个关键因素: 1. **容量**:初始容量和扩容...
Java的LinkedList可以作为队列使用,还有专门的Queue接口和其实现类如ArrayDeque。 树形数据结构中,二叉树是最常见的。在二叉树中,每个节点最多有两个子节点,分为左子节点和右子节点。二叉搜索树是一种特殊的...
在Java中,我们可以使用`java.util.Stack`类或者`java.util.Deque`接口的实现,如`ArrayDeque`,来创建和操作栈。 消息队列(Message Queue)是另一种常见的并发编程工具,它能有效地协调多个线程之间的通信。消息...
10. **堆栈和队列的组合**:如双端队列(Deque),Java的java.util.Deque接口及其实现类ArrayDeque可以提供这种功能。 每个数据结构都有其特定的插入、删除、查找等操作的复杂度,理解和掌握它们的特性是优化算法的...