队列遵循先进先出(FIFO First Input First Output )的原则。
Queue接口,同时使得LinkedList实现了该接口(选择LinkedList实现Queue的原因在于Queue经常要进行插入和删除的操作,而LinkedList在这方面效率较高)。
- boolean offer(E e):将元素追加到队列末尾,若添加成功则返回true。
- E poll():从队首删除并返回该元素。
- E peek():返回队首元素,但是不删除
- Queue<String> queue = new LinkedList<String>();
- queue.offer("a");
- queue.offer("b");
- queue.offer("c");
- System.out.println(queue); // [a, b, c]
- String str = queue.peek();
- System.out.println(str); // a
- while (queue.size() > 0) {
- str = queue.poll();
- System.out.print(str + " "); // a b c
- }
- Deque是Queue的子接口,定义了所谓“双端队列”即从队列的两端分别可以入队(offer)和出队(poll),LinkedList实现了该接口。
-
如果将Deque限制为只能从一端入队和出队,则可实现“栈”(Stack)的数据结构,对于栈而言,入栈称之为push,出栈称之为pop。
栈遵循先进后出(FILO First Input Last Output )的原则
-
- void push(E e):将给定元素"压入"栈中。存入的元素会在栈首。即:栈的第一个元素
- E pop():将栈首元素删除并返回。
- Deque<String> stack = new LinkedList<String>();
- stack.push("a");
- stack.push("b");
- stack.push("c");
- System.out.println(stack); // [c, b, a]
- String str = stack.peek();
- System.out.println(str); // c
- while (stack.size() > 0) {
- str = stack.pop();
- System.out.print(str + " "); // c b a
- }
LinkedHashMap实现有序的Map
-
Map 接口的哈希表和链表实现,具有可预知的迭代顺序。此实现与 HashMap 的不同之处在于,LinkedHashMap维护着一个双向循环链表。此链表定义了迭代顺序,该迭代顺序通常就是将存放元素的顺序。
需要注意的是,如果在Map中重新存入以有的key,那么key的位置会不会发生改变,只是将value值替换。