Java集合干货总结(一)

最近在准备Java实习生面试的过程中发现很多面Java基础时都会设计到集合相关的东西,所以准备总结一下集合相关的东西。
看过很多博客,大家大多以Collection下面的几大接口进行集合总结的,我准备以各个集合底层具体实现的数据结构为主线,附带集合的具体实现接口中的方法来进行总结。

队列:###

通常有两种实现方法:

  1. 使用循环数组,在Java中对应ArrayDeque
  2. 使用链表,在java中对应LinkedList类,同时该类实现了Queue接口

循环数组要比链表更加的高效,一般优先选择循环数组,但循环数组是一个有限集合,容量是有限制的。如果程序当中我们所需要容纳的集合元素是无限的责需要使用LinkedList 类 。后面我们将阐述它们底层的具体实现和具体使用方法,在这之前我们先了解一下集合中最重要的两个接口Collection和Iterator

Iterator接口#####

iterator()方法用于返回一个实现了Iterator接口的对象。可以使用这个迭代器对象依次访问集合中的元素。该接口中包含了三个方法:

public interface Iterator<E>{
   E next(); //迭代引用先后移动,返回此次移动越过的对象
   boolean hasNext(); //表示还有没有其他的元素
   void remove();  //移除迭代子最后一次越过的元素
}

因为Collection接口扩展了Iterable接口,因此对标准库中的任何集合都可以使用"for each"循环

for(String element : c){
   //do something with element
}

在Iterator的使用当中我认为应该理解注意以下几个方面:

  1. Java集合类库中的迭代器与其它类库中的迭代器在概念上有着重要的区别。其它地方迭代器是根据数组索引建模的。Java迭代器中查找操作与位置变更是紧密相连的。查找一个元素的唯一方法是调用next(),而在执行查找操作的同时,迭代器的位置随之向前移动。调用next(),迭代器就越过下一个元素,并返回刚刚越过的元素的引用
  2. next()方法和remove()方法是具有相互依赖性的。如果调用remove之前没有调用next将是不合法的。会抛出一个IllegalStateException异常。
  3. next方法调用到最后没有元素时将抛出NoSuchElementException,所以我们在调用next方法之前,应当先调用hasNext()方法。

PS:后面还会介绍一个listIterator()方法,是list接口的一个方法,LinkedList实现了这个接口,该接口还会提供向前遍历以及添加元素等一些功能,我们之后再讲。

Collection接口#####

除了Map结尾的集合类外,基本上都实现了Collection接口,它提供了很多实用的方法,后面我们便列出一些常用的方法:

//返回一个迭代器
Iterator<E> iterator();
//返回集合中元素的个数
int size();
//集合中是否包含该元素
boolean contains(Object obj);
//该集合是否包含other集合中的所有元素
boolean containsAll(Collection<?> other);
//想集合中添加一个元素,如果该调用改变了集合,返回true
boolean add(Object element);
//将other中的所有元素添加入集合
boolean addAll(Collection<? extends E> other);
//删除集合中等于obj的对象,如果匹配对象呗删除,返回true
boolean remove(Object obj);
//删除集合中所有other所含元素
boolean removeAll(Collection<?> other);
//删除集合中所有元素
void clear();
//从这个集合中删除所有与other集合中的元素不同的元素。如果由于这个调用改变了集合,返回true
boolean retainAll(Collection<?> other);
//返回这个集合的对象数组
Object[] toArray();
//返回这个集合的对象数组,如果arrayToFill足够大,就将集合中的元素填入这个数组中,剩余空间用null填补,否则分配一个新数组,其成员类型与arrayToFill的成员类型相同,其长度等于集合的大小,并填入集合元素
<T> T[] toArray(T[] arrayToFill);

现在我们对集合有了一个基本的了解,下面我们根据底层数据结构来讲解具体的集合。

链表(Link)来讲解LinkedList###

在Java中,所有链表实际上都是双向链接的(doubly linked),每个节点还存放着指向前驱节点的引用。为了方便我就直接贴上来LinkedList的API。

LinkedList.png
LinkedList.png

LinkedList.png

链表是一个有序集合,每个对象的位置都十分的重要。LinkedList.add()方法将对象添加到链表的尾部。但是我们常常需要讲一个元素添加到链表的中间。由于迭代器是描述集合中的位置,集合类库提供了子接口ListIterator,其中是包含add()方法的
listIterator.png

上面就是ListIterator所包含的方法,次对象可由LinkedList的listIterator()方法获取,该方法是list接口中的,而LinkedList便实现了该接口所有有此方法。我们在使用过程中需要注意:

  1. add方法只依赖于迭代器的位置,而remove方法依赖于迭代器的状态,如果将我们的迭代器比作光标,则add()方法便将元素插入到光标前,remove方法便是我们的backspace操作。
  2. 多个迭代器同时访问一个集合,如果迭代器发现它的集合被另一个迭代器修改了,就会抛出一个Concurrent ModificationException异常,为了避免发生并发修改异常,我们可以根据需要给容器附加许多的迭代器,但是这些迭代器智能读取列表。另外,再单独附加一个既能读又能写的迭代器。
  3. 链表是不支持随机访问的,如果要查找一个元素,就必须从头开始查找,下面有一种效率很低的做法,尽管get()方法做了微小的优化,当索引大于size()/2就从列表尾端开始搜索元素
for(int i = 0 ; i< list.size() ; i++){
   do something with list.get(i);//因为做不到缓存位置信息的操作,所以每次get都要从头开始
}

先总结到这儿吧,以后有关List的一些特性放到ArrayList的分析中去

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容