第九章 集合

Java集合框架

  • Java集合类库也将接口与实现implementation分离
  • 集合类的基本接口是Collection接口,这个接口有两个基本方法:boolean add(E element)和Iterator<E> Iterator()
  • 迭代器Iterator接口包含4个方法:next(),hasNext(),remove(),forEachRemaining(Consumer<? super E> action);
  • Collection接口扩展类Iterable接口。
  • 元素被访问的类型取决于集合类型
  • Collection接口还声明很多有用的方法;size(),isEmpty(),contains(),containsAll(),equals(),addAll(),remove(),removeAll(),clear(),retainAll(),toArray();
  • 为了让实现者更容易地实现Collection接口,类库提供类一个类AbstractCollection
  • 集合有两个基本接口http://www.codes51.com/article/detail_358737.html
  • 由于Map包含键值对,所以用put方法插入,用get方法读取
  • LIst是一个有序集合ordered Collection。元素会增加到容器中的特定位置。可以采用两种方式访问元素:使用迭代器访问,或者使用一个整数索引来访问。后一种方法被称为随机访问random access ,因为这样可以按任意顺序访问元素。与之不同,使用迭代器访问时,必须顺序地访问元素。
  • List接口定义了多个用于随机访问的方法:add(index,element);remove(index);get(index);get(index,element);
  • Set接口等同于Collection接口。set的add方法不允许增加重复的元素。

具体的集合

ArrayList:一种可以动态增长和缩减的索引序列
LinkedList:一种可以在任何位置进行高效地插入和删除操作的有序序列
ArrayDeque:一种用循环数组实现的双端队列
HashSet:一种没有重复元素的无序集合
TreeSet:有序集
EnumSet:一种包含枚举类型值的集
LinkedHashSet:一种可以记住元素插入次序的集
PriorityQueue:一种允许高效删除最小元素的集合
HashMap:一种存储键值关联的数据结构
TreeMap:一种键值有序排列的映射表
EnumMap:一种键值属于枚举类型的映射表
LinkedHashMap:一种可以记住键值添加次序的映射表
WeakHashMap:一种其值无用武之地后可以被垃圾回收期回收的映射表
IdentityHashMap:一种用==而不是用equals比较键值的映射表
  • 链表LinkedList是一种有序集合,每个对象的位置十分重要。
  • ArrayList:List接口用于描述一个有序集合,并且集合中每个元素的位置十分重要。有两种访问元素的协议:一种是用迭代器,另一种是用get和set方法随机地访问每个元素。后者不适合LinkedList,但对数组却很有用。ArrayList也实现类List接口,封装了一个动态再分配的对象数组。
  • 在不需要同步时使用ArrayList,而不要使用Vector
  • HashSet
  • TreeSet是一个有序集合,可以以任意顺序将元素插入到集合中。在对集合进行遍历时,每个值将自动地按照排序后的顺序呈现。它的排序是用红黑树结构实现的。
  • Deque,双端队列
  • 优先级队列priorityQueue:可以按任意顺序插入,却总是按照排序后的顺序进行检索,它使用的数据结构是堆heap。堆是一个可以自我调整的二叉树。

映射

  • 通常,我们知道某些键的信息,并想要查找与之对应的元素,Map数据结构为此设计。映射用来存放键值对,如果提供了键,就能够查找到值。
  • 散列映射对键进行散列,树映射用键的整体顺序对元素进行排序,并将其组织成搜索树。散列和比较函数只能作用于键
  • 与Set一样,如果不需要按照排列顺序访问键,最好选择HashMap,而不是TreeMap。
  • 要想检索一个对象,必须使用一个键
  • 映射视图view
  • 弱散列映射WeakHashMap
  • LinkedHashSet 和 LinkedHashMap用来记住插入元素项的顺序

视图与包装器

  • 轻量级集合包装器
  • 子范围
  • 不可修改的视图unmodifiable views
  • 同步视图
  • 受查视图

算法

  • 泛型集合接口有一个很大的优点,即算法只需要实现一次。
  • 排序和混排
  • 二分查找binarysearch
  • 批操作
  • 集合与数组的转换

遗留的集合

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

推荐阅读更多精彩内容