6 集合

java2之前

枚举(Enumeration)接口:定义了一种从数据结构中取回连续元素的方式。

位集合(BitSet)类:实现了一组可以单独设置和清除的位或标志。

向量(Vector)类:相当于动态数组,可以动态改变数组大小。

栈(Stack) Vector子类:实现了一个后进先出(LIFO)的数据结构。

字典(Dictionary)抽象类:定义了键映射到值的数据结构(作用和Map类相似)。

哈希表(Hashtable)类:提供了一种在用户定义键结构的基础上来组织数据的手段(已被继承到集合框架中)。

属性(Properties)Hashtable.Properties子类:表示了一个持久的属性集.属性列表中每个键及其对应值都是一个字符串。

缺点:缺少核心,统一的主题


java2新引入

集合框架(Collection)

结构
常用

Collection接口:

Collection接口是最基本的集合接口,它不提供直接的实现,Java SDK提供的类都是继承自Collection的“子接口”如List和Set。它代表的是一种规则,如是否允许重复,是否支持排序等。


使用场景

List VS Set VS Map

List:1.元素有放入顺序,元素可重复;

         2.查找元素效率高,插入删除元素效率低(会引起其他元素位置改变);

Set:1.元素无放入顺序,元素不可重复,重复元素会覆盖掉;

         2.检索元素效率低,删除和插入效率高(插入和删除不会引起元素位置改变);

Map:适合储存键值对的数据;


ArrayList VS LinkedList

ArrayList:1.基于 动态数组 的数据结构,地址连续(在内存里是连着放的)

                  2.查询效率高,插入和删除操作效率低(要移动数据)

LinkedList:1.基于 链表 的数据结构,地址任意(开辟内存空间时不需要等一个连续的地址)

                    2.查询效率低(要移动指针),插入删除效率高,适合头尾操作(双链表)或插入指定位置

注:实际还需看情况,单条数据插入或删除:ArrayList > LinkedList ;

                                    批量随机的插入删除:LinkedList > ArrayList;


HashSet VS Treeset

HashSet:1.基于HashMap实现

                  2.无序

                  3.可以放入null,但只能有一个null,值不能重复    

                  4.性能通常优于TreeSet(因为基于Hash算法实现),适合快速查找

TreeSet:1.基于二叉树(红黑树结构)

                 2.有序

                 3.不可以放入null值,值不能重复

                 4.适用于需要排序的功能时


HashMap VS TreeMap VS HashTable

HashMap:1.基于哈希表实现(底层实现是数组,数组每一项是链表)

                   2.无序(是指插入k1,k2,k3,遍历时顺序未必是k1,k2,k3)

                   3.key,value允许为空

                   4.适用于Map中插入、删除和定位元素

TreeMap:1.基于红黑树的数据结构

                  2.有序

                  3.不允许键对象为 null 或是 基本数据类型(因为 TreeMap 中的对象必须是可排序的)

                  4.适用于按自然顺序或自定义顺序遍历键(key)

HashTable:与HashMap相似的实现

                     区别:1.key,value不允许为空

                                2.线程安全

性能:HashMap > HashTable > TreeMap (因素:基于hash算法和线程安全)


线程安全对比

非线程安全:LinkedList,ArrayList,HashSet,HashMap,TreeMap,StringBuilder

线程安全:Vector,HashTable,StringBuffer


集合的有序、无序、排序性质

有序、无序:是指插入元素时,保持插入的顺序性,也就是先插入的元素优先放入集合的前面部分。

排序:是指插入元素后,集合中的元素是否自动排序。(例如升序排序)

有序集合:集合里的元素可以根据key或index访问(有序集合在属性的增加,删除及修改中拥有较好的性能表现)

无序集合:集合里的元素只能遍历。

HashMap、 HashSet、 HashTable 等 基于哈希存储方式的集合是无序的。其它的集合都是有序的。

TreeMap TreeSet 等集合是排序的。


对集合的选择

对List的选择 :

1.对于随机查询与迭代遍历操作,数组比所有的容器都要快。所以在随机访问中一般使用ArrayList

2.LinkedList使用双向链表对元素的增加和删除提供了非常好的支持,而ArrayList执行增加和删除元素需要进行元素位移。

3.对于Vector而已,我们一般都是避免使用。

4.将ArrayList当做首选,毕竟对于集合元素而已我们都是进行遍历,只有当程序的性能因为List的频繁插入和删除而降低时,再考虑LinkedList。

对Set的选择:

1、HashSet由于使用HashCode实现,所以在某种程度上来说它的性能永远比TreeSet要好,尤其是进行增加和查找操作。

2、虽然TreeSet没有HashSet性能好,但是由于它可以维持元素的排序,所以它还是存在用武之地的。

对Map的选择:

1、HashMap与HashSet同样,支持快速查询。

     虽然HashTable速度的速度也不慢,但是在HashMap面前还是稍微慢了些,所以HashMap在查询方面可以取代HashTable。

2、由于TreeMap需要维持内部元素的顺序,所以它通常要比HashMap和HashTable慢。


fail-fast机制( throw ConcurrentModificationException)

简介:“快速失败”是Java集合的一种错误检测机制。

            eg:当多个线程对集合进行结构上的改变的操作时,有可能会产生fail-fast机制。

作用:不用等迭代完再告诉你出错了

解决:使用CopyOnWriteArrayList来替换ArrayList

CopyOnWriteArrayList

简介:ArrayList 的一个线程安全的变体,其中所有可变操作(add、set 等等)都是通过对底层数组进行一次新的复制来实现的。

适用场景:1.在不能或不想进行同步遍历,但又需要从并发线程中排除冲突时;

                  2.当遍历操作的数量大大超过可变操作的数量时;

原理:任何对array在结构上有所改变的操作(add、remove、clear等),都会copy原有数据,在copy的数据上修改,不会影响原有数据,修改                完成后改变原有数据的引用。

缺点:开销大,产生大量对象,copy数组损耗大


集合使用细节

关于Array.asList:

       1.在使用asList时不要将基本数据类型当做参数;

        (asList参数接收泛型,基本数据类型无法泛型化,若传int[],则是将数组这个对象泛型化,永远size只有1,需要用Integer[])

       2.Arrays.asList()返回的ArrayList是Arrays类的一个内部类(不是java.util.ArrayList),不具备add,remove,长度不可变;

关于subList:

       1.subList返回的只是原列表的一个视图,它所有的操作最终都会作用在原列表上;

       2.生成子列表后,不要试图去操作原列表,否则会造成子列表的不稳定而产生异常;(Collections.unmodifiableList(list)//将原列表设为只读)

       (推荐:使用subList处理局部列表)

应用

Collections集合工具类:comparable接口(只能bean内部实现排序规则),compator(独立bean外部做排序规则)

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

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,605评论 18 399
  • Collection ├List │├LinkedList │├ArrayList │└Vector │└Stac...
    AndyZX阅读 873评论 0 1
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,644评论 18 139
  • 不怎么看鸡汤软文的我,突然写点东西感觉瞬间词穷了。其实没有想感慨什么,只是发觉时间过得太快,还没好好感受和回味,已...
    ZPeiweN阅读 180评论 0 0
  • 前言 自从小tan上次出了一篇关于用Sketch制作自定义的APP下拉刷新GIF动画后,有不少小伙伴说期待出一篇关...
    peaktan阅读 34,512评论 34 91