how2j.cn


工具版本兼容问题
序列分先进先出FIFO,先进后出FILO
FIFO在Java中又叫Queue 队列
FILO在Java中又叫Stack 栈

本视频是解读性视频,所以希望您已经看过了本知识点的内容,并且编写了相应的代码之后,带着疑问来观看,这样收获才多。 不建议一开始就观看视频



7分58秒
本视频采用html5方式播放,如无法正常播放,请将浏览器升级至最新版本,推荐火狐,chrome,360浏览器 如果装有迅雷,播放视频呈现直接下载状态,请调整 迅雷系统设置-基本设置-启动-监视全部浏览器 (去掉这个选项)



示例 1 : LinkedList 与 List接口   
示例 2 : 双向链表 - Deque   
示例 3 : 队列 - Queue   
示例 4 : ArrayList 与 LinkedList的区别   
示例 5 : 练习-使用LinkedList实现Stack栈   
示例 6 : 答案-使用LinkedList实现Stack栈   

示例 1 :

LinkedList 与 List接口

ArrayList一样,LinkedList也实现了List接口,诸如add,remove,contains等等方法。 详细使用,请参考 ArrayList 常用方法,在此不作赘述。

接下来要讲的是LinkedList的一些特别的地方
示例 2 :

双向链表 - Deque

除了实现了List接口外,LinkedList还实现了双向链表结构Deque,可以很方便的在头尾插入删除数据

什么是链表结构: 与数组结构相比较,数组结构,就好像是电影院,每个位置都有标示,每个位置之间的间隔都是一样的。 而链表就相当于佛珠,每个珠子,只连接前一个和后一个,不用关心除此之外的其他佛珠在哪里。
双向链表 - Deque
package collection; import java.util.LinkedList; import charactor.Hero; public class TestCollection { public static void main(String[] args) { //LinkedList是一个双向链表结构的list LinkedList<Hero> ll =new LinkedList<Hero>(); //所以可以很方便的在头部和尾部插入数据 //在最后插入新的英雄 ll.addLast(new Hero("hero1")); ll.addLast(new Hero("hero2")); ll.addLast(new Hero("hero3")); System.out.println(ll); //在最前面插入新的英雄 ll.addFirst(new Hero("heroX")); System.out.println(ll); //查看最前面的英雄 System.out.println(ll.getFirst()); //查看最后面的英雄 System.out.println(ll.getLast()); //查看不会导致英雄被删除 System.out.println(ll); //取出最前面的英雄 System.out.println(ll.removeFirst()); //取出最后面的英雄 System.out.println(ll.removeLast()); //查看会导致英雄被删除 System.out.println(ll); } }
示例 3 :

队列 - Queue

LinkedList 除了实现了List和Deque外,还实现了Queue接口(队列)。
Queue是先进先出队列 FIFO,常用方法:
offer 在最后添加元素
poll 取出第一个元素
peek 查看第一个元素
队列 - Queue
package collection; import java.util.LinkedList; import java.util.List; import java.util.Queue; import charactor.Hero; public class TestCollection { public static void main(String[] args) { //和ArrayList一样,LinkedList也实现了List接口 List ll =new LinkedList<Hero>(); //所不同的是LinkedList还实现了Deque,进而又实现了Queue这个接口 //Queue代表FIFO 先进先出的队列 Queue<Hero> q= new LinkedList<Hero>(); //加在队列的最后面 System.out.print("初始化队列:\t"); q.offer(new Hero("Hero1")); q.offer(new Hero("Hero2")); q.offer(new Hero("Hero3")); q.offer(new Hero("Hero4")); System.out.println(q); System.out.print("把第一个元素取poll()出来:\t"); //取出第一个Hero,FIFO 先进先出 Hero h = q.poll(); System.out.println(h); System.out.print("取出第一个元素之后的队列:\t"); System.out.println(q); //把第一个拿出来看一看,但是不取出来 h=q.peek(); System.out.print("查看peek()第一个元素:\t"); System.out.println(h); System.out.print("查看并不会导致第一个元素被取出来:\t"); System.out.println(q); } }
示例 4 :

ArrayList 与 LinkedList的区别

ArrayList 与 LinkedList的区别是面试常常会问到的考题
具体区别,详见 ArrayList 与 LinkedList的区别
示例 5 :

练习-使用LinkedList实现Stack栈

Or  姿势不对,事倍功半! 点击查看做练习的正确姿势
FIFO(先入先出的)队列类似的一种数据结构是FILO先入后出Stack
根据接口Stack :
实现类:MyStack

public class MyStack implements Stack

并向这个栈中,压入5个英雄,接着弹出5个英雄

再解释一下栈: 栈的结构,就像给弹夹添加子弹一样,先添加的子弹,就放在了最下面,打手枪的时候,只能从最上面取子弹。
练习-使用LinkedList实现Stack栈
package collection; import charactor.Hero; public interface Stack { //把英雄推入到最后位置 public void push(Hero h); //把最后一个英雄取出来 public Hero pull(); //查看最后一个英雄 public Hero peek(); }
package collection;

import charactor.Hero;

public interface Stack {

	//把英雄推入到最后位置
	public void push(Hero h); 
	//把最后一个英雄取出来
	public Hero pull(); 
	//查看最后一个英雄
	public Hero peek();
}
示例 6 :

答案-使用LinkedList实现Stack栈

在查看答案前,尽量先自己完成,碰到问题再来查看答案,收获会更多
本视频是解读性视频,所以希望您已经看过了本答案的内容,带着疑问来观看,这样收获才多。 不建议一开始就观看视频

5分9秒 本视频采用html5方式播放,如无法正常播放,请将浏览器升级至最新版本,推荐火狐,chrome,360浏览器 如果装有迅雷,播放视频呈现直接下载状态,请调整 迅雷系统设置-基本设置-启动-监视全部浏览器 (去掉这个选项)


package collection; import java.util.LinkedList; import charactor.Hero; public class MyStack implements Stack{ LinkedList<Hero> heros = new LinkedList<Hero>(); @Override public void push(Hero h) { heros.addLast(h); } @Override public Hero pull() { return heros.removeLast(); } @Override public Hero peek() { return heros.getLast(); } public static void main(String[] args) { MyStack heroStack = new MyStack(); for (int i = 0; i < 5; i++) { Hero h = new Hero("hero name " + i); System.out.println("压入 hero:" + h); heroStack.push(h); } for (int i = 0; i < 5; i++) { Hero h =heroStack.pull(); System.out.println("弹出 hero" + h); } } }


HOW2J公众号,关注后实时获知布最新的教程和优惠活动,谢谢。


问答区域    
2018-04-11 请问既然LinkedList以及实现了getfirst、getlast以及remove 那Queue接口offer 以及 poll peek 意义是什么 可以简单说下哪些场合需要这两种方式的区分吗
bartimos
请问既然LinkedList以及实现了getfirst、getlast以及remove 那Queue接口offer 以及 poll peek 意义是什么 可以简单说下哪些场合需要这两种方式的区分吗








答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到




2017-10-16 LinkedList中的addFrist函数和addLast函数问题
weichen



你好!为什么LinkedList中的addFrist函数和addLast函数获取到的元素都是同一元素? 注:容量>1
System.out.println(ll.getFirst().name);
		System.out.println(ll.size());		//这里已为6
		System.out.println(ll.getLast().name);	//最后一个元素和第一个元素一样,why?

							


2 个答案

weichen 答案时间:2017-10-19
试过了,没有没问题。我当时用static成员,发现静态成员是所有对象共享的,所以不断覆盖。谢谢站长

how2j 答案时间:2017-10-17
怎么可能呢,你看这段为了回答你的问题专门写的代码,你运行试试呢




答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到





2017-09-12 错别字
2016-12-19 示例四的超链接错了
2016-05-20 其实后面的q也能改成ll的吧?




提问之前请登陆
关于 JAVA 中级-集合框架-LinkedList 的提问

尽量提供截图代码异常信息,有助于分析和解决问题。 也可进本站QQ群交流: 620943819
站长会在每个工作日早上尽量回答提问(如果有漏掉没有回答的,请进群提醒一下)
提问尽量提供完整的代码,环境描述,越是有利于问题的重现,您的问题越能更快得到解答。
对教程中代码有疑问,请提供是哪个步骤,哪一行有疑问,这样便于快速定位问题,提高问题得到解答的速度
站长是玻璃心,提问的时候请语气温柔些 kiss~
截止2017-5-19日累计提问 1638个,站长回答了 1546个
截止2017-8-15日累计提问 2788个,站长回答了 2544个

上传截图