Java 教程
- Java - 首頁
- Java - 概述
- Java - 歷史
- Java - 特性
- Java 與 C++
- JVM - Java 虛擬機器
- Java - JDK 與 JRE 與 JVM
- Java - Hello World 程式
- Java - 環境搭建
- Java - 基本語法
- Java - 變數型別
- Java - 資料型別
- Java - 型別轉換
- Java - Unicode 系統
- Java - 基本運算子
- Java - 註釋
- Java - 使用者輸入
- Java - 日期與時間
Java 控制語句
- Java - 迴圈控制
- Java - 決策制定
- Java - If-else
- Java - Switch
- Java - For 迴圈
- Java - For-Each 迴圈
- Java - While 迴圈
- Java - do-while 迴圈
- Java - Break
- Java - Continue
面向物件程式設計
- Java - OOPs 概念
- Java - 物件與類
- Java - 類屬性
- Java - 類方法
- Java - 方法
- Java - 變數作用域
- Java - 構造方法
- Java - 訪問修飾符
- Java - 繼承
- Java - 聚合
- Java - 多型
- Java - 重寫
- Java - 方法過載
- Java - 動態繫結
- Java - 靜態繫結
- Java - 例項初始化塊
- Java - 抽象
- Java - 封裝
- Java - 介面
- Java - 包
- Java - 內部類
- Java - 靜態類
- Java - 匿名類
- Java - 單例類
- Java - 包裝類
- Java - 列舉
- Java - 列舉構造方法
- Java - 列舉字串
Java 內建類
Java 檔案處理
Java 錯誤與異常
- Java - 異常
- Java - try-catch 塊
- Java - try-with-resources
- Java - 多重捕獲塊
- Java - 巢狀 try 塊
- Java - Finally 塊
- Java - throw 異常
- Java - 異常傳播
- Java - 內建異常
- Java - 自定義異常
Java 多執行緒
- Java - 多執行緒
- Java - 執行緒生命週期
- Java - 建立執行緒
- Java - 啟動執行緒
- Java - 執行緒連線
- Java - 執行緒命名
- Java - 執行緒排程器
- Java - 執行緒池
- Java - 主執行緒
- Java - 執行緒優先順序
- Java - 守護執行緒
- Java - 執行緒組
- Java - 關閉鉤子
Java 同步
Java 網路
- Java - 網路
- Java - 套接字程式設計
- Java - URL 處理
- Java - URL 類
- Java - URLConnection 類
- Java - HttpURLConnection 類
- Java - Socket 類
- Java - 泛型
Java 集合
Java 介面
Java 資料結構
Java 集合演算法
高階 Java
- Java - 命令列引數
- Java - Lambda 表示式
- Java - 傳送郵件
- Java - Applet 基礎
- Java - Javadoc 註釋
- Java - 自動裝箱和拆箱
- Java - 檔案不匹配方法
- Java - REPL (JShell)
- Java - 多版本 Jar 檔案
- Java - 私有介面方法
- Java - 內部類菱形運算子
- Java - 多解析度影像 API
- Java - 集合工廠方法
- Java - 模組系統
- Java - Nashorn JavaScript
- Java - Optional 類
- Java - 方法引用
- Java - 函式式介面
- Java - 預設方法
- Java - Base64 編碼解碼
- Java - Switch 表示式
- Java - Teeing 收集器
- Java - 微基準測試
- Java - 文字塊
- Java - 動態 CDS 歸檔
- Java - Z 垃圾收集器 (ZGC)
- Java - 空指標異常
- Java - 打包工具
- Java - 密封類
- Java - 記錄類
- Java - 隱藏類
- Java - 模式匹配
- Java - 簡潔數字格式化
- Java - 垃圾回收
- Java - JIT 編譯器
Java 雜項
- Java - 遞迴
- Java - 正則表示式
- Java - 序列化
- Java - 字串
- Java - 程序 API 改進
- Java - 流 API 改進
- Java - 增強的 @Deprecated 註解
- Java - CompletableFuture API 改進
- Java - 流
- Java - 日期時間 API
- Java 8 - 新特性
- Java 9 - 新特性
- Java 10 - 新特性
- Java 11 - 新特性
- Java 12 - 新特性
- Java 13 - 新特性
- Java 14 - 新特性
- Java 15 - 新特性
- Java 16 - 新特性
Java API 與框架
Java 類參考
- Java - Scanner
- Java - 陣列
- Java - 字串
- Java - Date
- Java - ArrayList
- Java - Vector
- Java - Stack
- Java - PriorityQueue
- Java - LinkedList
- Java - ArrayDeque
- Java - HashMap
- Java - LinkedHashMap
- Java - WeakHashMap
- Java - EnumMap
- Java - TreeMap
- Java - IdentityHashMap
- Java - HashSet
- Java - EnumSet
- Java - LinkedHashSet
- Java - TreeSet
- Java - BitSet
- Java - Dictionary
- Java - Hashtable
- Java - Properties
- Java - Collection
- Java - Array
Java 有用資源
Java - Deque 介面
Deque 介面在 java.util 包中提供,它擴充套件了 Queue 介面。它是一個線性集合,支援在兩端插入和刪除元素。此介面定義了訪問雙端佇列兩端元素的方法。提供了插入、刪除和檢查元素的方法。
宣告
public interface Deque<E> extends Queue<E>
Deque 方法
以下是 Deque 介面的所有實現類都實現的重要雙端佇列方法列表 -
| 序號 | 方法及描述 |
|---|---|
| 1 | boolean add(E e)
此方法將指定的元素插入到由該雙端隊列表示的佇列中(換句話說,在該雙端佇列的尾部),如果可以立即這樣做而不違反容量限制,則返回 true,如果當前沒有可用空間,則丟擲 IllegalStateException。 |
| 2 | boolean addAll(Collection<? extends E> c)
此方法將指定集合中的所有元素新增到該雙端佇列的末尾,就像對每個元素呼叫 addLast(E) 一樣,按照集合的迭代器返回的順序。 |
| 3 | void addFirst(E e)
此方法將指定的元素插入到該雙端佇列的前面,如果可以立即這樣做而不違反容量限制,則丟擲 IllegalStateException 如果當前沒有可用空間。 |
| 4 | void addLast(E e)
此方法將指定的元素插入到該雙端佇列的末尾,如果可以立即這樣做而不違反容量限制,則丟擲 IllegalStateException 如果當前沒有可用空間。 |
| 5 | boolean contains(Object o)
此方法如果該雙端佇列包含指定的元素,則返回 true。 |
| 6 | Iterator<E> descendingIterator()
此方法返回一個迭代器,該迭代器按反向順序遍歷此雙端佇列中的元素。 |
| 7 | E element()
此方法檢索但不刪除由該雙端隊列表示的佇列的頭(換句話說,該雙端佇列的第一個元素)。 |
| 8 | E getFirst()
此方法檢索但不刪除該雙端佇列的第一個元素。 |
| 9 | E getLast()
此方法檢索但不刪除該雙端佇列的最後一個元素。 |
| 10 | Iterator<E> iterator()
此方法返回一個迭代器,該迭代器按正確的順序遍歷此雙端佇列中的元素。 |
| 11 | boolean offer(E e)
此方法將指定的元素插入到由該雙端隊列表示的佇列中(換句話說,在該雙端佇列的尾部),如果可以立即這樣做而不違反容量限制,則返回 true,如果當前沒有可用空間,則返回 false。 |
| 12 | boolean offerFirst(E e)
此方法將指定的元素插入到該雙端佇列的前面,除非這會違反容量限制。 |
| 13 | boolean offerLast(E e)
此方法將指定的元素插入到該雙端佇列的末尾,除非這會違反容量限制。 |
| 14 | E peek()
此方法檢索但不移除此雙端隊列表示的佇列的頭(換句話說,此雙端佇列的第一個元素),如果此雙端佇列為空則返回 null。 |
| 15 | E peekFirst()
此方法檢索但不移除此雙端佇列的第一個元素,如果此雙端佇列為空則返回 null。 |
| 16 | E peekLast()
此方法檢索但不移除此雙端佇列的最後一個元素,如果此雙端佇列為空則返回 null。 |
| 17 | E poll()
此方法檢索並移除此雙端隊列表示的佇列的頭(換句話說,此雙端佇列的第一個元素),如果此雙端佇列為空則返回 null。 |
| 18 | E pollFirst()
此方法檢索並移除此雙端佇列的第一個元素,如果此雙端佇列為空則返回 null。 |
| 19 | E pollLast()
此方法檢索並移除此雙端佇列的最後一個元素,如果此雙端佇列為空則返回 null。 |
| 20 | E pop()
此方法從此雙端隊列表示的棧中彈出元素。 |
| 21 | void push(E e)
此方法將元素壓入此雙端隊列表示的棧(換句話說,在該雙端佇列的頭部),如果可以立即執行而不會違反容量限制,則丟擲 IllegalStateException 如果當前沒有可用空間。 |
| 22 | E remove()
此方法檢索並移除此雙端隊列表示的佇列的頭(換句話說,此雙端佇列的第一個元素)。 |
| 23 | E removeFirst()
此方法檢索並移除此雙端佇列的第一個元素。 |
| 24 | boolean removeFirstOccurrence(Object o)
此方法從此雙端佇列中移除指定元素的第一次出現。 |
| 25 | E removeLast()
此方法檢索並移除此雙端佇列的最後一個元素。 |
| 26 | boolean removeLastOccurrence(Object o)
此方法從此雙端佇列中移除指定元素的最後一次出現。 |
| 27 | int size()
此方法返回此雙端佇列中的元素數量。 |
繼承的方法
此介面繼承自以下介面:
- java.util.Queue
- java.util.Collection
- java.lang.Iterable
示例
在此示例中,我們使用 Deque 例項來演示雙端佇列的新增、檢視和大小操作。
package com.tutorialspoint;
import java.util.ArrayDeque;
import java.util.Deque;
public class DequeDemo {
public static void main(String[] args) {
Deque<Integer> q = new ArrayDeque<>();
q.add(6);
q.add(1);
q.add(8);
q.add(4);
q.add(7);
System.out.println("The deque is: " + q);
int num1 = q.remove();
System.out.println("The element deleted from the head is: " + num1);
System.out.println("The deque after deletion is: " + q);
int head = q.peek();
System.out.println("The head of the deque is: " + head);
int size = q.size();
System.out.println("The size of the deque is: " + size);
}
}
輸出
The deque is: [6, 1, 8, 4, 7] The element deleted from the head is: 6 The deque after deletion is: [1, 8, 4, 7] The head of the deque is: 1 The size of the deque is: 4