java中线性表_Java Se :线性表

Java的集合框架分为两个系列,Collection和Map系列。在大学期间,学习数据结构时,好像学习了线性表、非线性表、树,哎,都给忘了。其实,在Collection系列内部又可以分为线性表、集合两大类。

常用的线性表有:ArrayList、LinkedList、Vector、Stack、Queue。

其中Stack、Queue是特殊的线性表。他们的特殊性表现在:

Stack是先进后出,FILO,也叫后进先出:LIFO。

Queue是先进先出,FIFO。

Collection系列中还有Set集。他们的实现比较复杂。后续将说明。

另外一个系列是Map,Dictionary为代表的集合,具体如何实现,将在后续说明。

ArrayList

正如它的名字一样,JDK中确实是使用数组实现的。elementData就是。

01a8e16536ac6c1eb17a46b14fbed050.png

另外,这个类中也提供了直接转为数组的方法:

4975d2153b73dc22dba48960d831e8c3.png

数组的特征是可以快速查询,但是插入、删除操作不方便。

LinkedList

看到这个名字,你可能会想到他是个单链表。如果这样想,只能说是对了一半。它确实是个链表,但不是一个单链表,而是一个双向链表。

下面看看源码:

697d6189ce6a3062edcf2e11d921a977.png

看看这个Entry到底是个什么玩意:

16e6e6ad1225842cdf60a2a37d153896.png

如果是单链表,有next就可以了,而不需要有previous。

双向链表的特征是:查找不方便,增删方便。

Vector

Vector汉语意思是向量,从名字上就可以知道是一个可变的集合。它是一个可变数组。

cd01e7cbf1815c329c3bdf06e0dcacd7.png

它和ArrayList都采用数组实现,但是他俩个有明显的区别,而这个问题也是面试时常会考到的问题。

Stack

Stack,后进先出,也就是说每次取数,都是取出最后一个。

这个特性实现起来一点也不难,使用数组就可以实现了。接下来看看JDK中是如何实现的:

d482783680b44b78f1d750e4efa3899b.png

JDK中也是使用数组的。

Queue

这是一个接口,在并发编程中使用很多。下面列出了Queue的实现类:

f6f4d1d33104f6abff660c550995e0a0.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值