第一篇 Java集合总览

Collection Framework 总览
官方的Collection

本文参考于:Collections in Java,刚兴趣的可以直接去看原文,不错的网站。

Collection Framework的历史渊源

在引入Collection Framework(即 JDK 1.2)之前,Java 处理多个对象的标准方法只有3种方法:
1.数组(array);
2.Vector;
3.Hashtable;
且三者之间没有公共的接口。
这样就造成在开发中,苦逼的程序猿不得不针对3种不同的实现来进行相应的操作。因为三者都有各自不同的方法和语法来处理成员。
给个栗子:

   public static void main(String[] args) {

        // create an instance of Array.
        int[] array = new int[]{1,2,3,4};
      
        // create an instance of Vector
        Vector<Integer> vector = new Vector<>(5);
        for (int i = 1; i < 5; i++) {
            vector.addElement(i);
        }
        // create an instance of Hashtable
        Hashtable<Integer,String> hashtable = new Hashtable<>(5);
        hashtable.put(1,"First");
        hashtable.put(2,"Second");
        hashtable.put(3,"Third");
        hashtable.put(4,"Fourth");
        // accessing first element of array,vector,hashtable.
  
        System.out.println("数组中的第一个元素:"+array[0]);
        System.out.println("Vector中的第一个元素:"+vector.elementAt(0));
        System.out.println("Hashtable中的第一个元素:"+hashtable.get(1));
         /**
         * 访问元素时,
         * Array 使用[], 
         * Vector 使用elementAt(), 
         * Hashtable 使用get().
         */
    }

从代码中我们可以发现,这三者(Array,Vector or Hashtable) 都没有实现一个标准的访问接口。所以编程人员难以对不同的集合写出通用的算法。另一个缺点是,Vector的很多方法都是final的,So我们没办法你通过继承Vector来实现相同的功能。

为了解决上述的问题,在JDK 1.2Java开发人员提出一个公共的接口并且引入了Collection Framework.并且修改了Vector 和 Hashtable来顺应这个Collection Framework.

JDK 1.2 引入了 Collection Framework.

Collection Framework的优势

集合框架的优势大致有以下三点:
1.稳健的API:这个API中包含一些接口,例如Collection, Set, List, and Map。其他的一些类(如ArrayList, LinkedList, Vector etc)都实现了这些接口,与此同时,这些接口中有一些公共的方法;
2.减轻编程负担:编程人员不必担心集合的设计,而可以在项目中集中精力地使用它;
3.提高程序的速度和质量:集合框架使用了高性能的数据结构和算法,从而提高了程序的性能;

Collection Framework的继承层次关系


             Collection                Map
         /     /    \      \            |
        /      /      \     \           |
     Set    List    Queue  Dequeue   SortedMap
     /
    /
 SortedSet 
            <strong>Core Interfaces in Collections</strong>
这里仅仅给出的是核心接口
  • Collection:顶层接口,它有基本的方法(add(),remove(),... etc.)
  • Set : 不允许元素重复(即不存在e1.equals(e2),最多只有一个null元素)。实现该接口有HashSet(基于HashCode)和TreeSet(基于平衡二叉树).值得注意的是,TreeSet implements SortedSet.
  • List:有序,且可以包含重复元素。其子类有(LinkedList and ArrayList ...)
  • Queue:遵守FIFO规则,当然也有一些例外(如 PriorityQueue...)
  • Deque:双端队列,允许在两端进行插入和删除。即可以FIFO and LIFO.
  • Map:键值对。键不允许重复。TreeMap implements SortedMap.
    Set 和 Map的区别在于,Set中只含有键,在Map中含有的是键值对。
具体的框架层次

欢迎查看下篇文章:详谈List

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

推荐阅读更多精彩内容

  • Collection ├List │├LinkedList │├ArrayList │└Vector │└Stac...
    AndyZX阅读 869评论 0 1
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,571评论 18 399
  • 3.3 集合 一方面, 面向对象语言对事物的体现都是以对象的形式,为了方便对多个对象的操作,就要对对象进行存储。另...
    闫子扬阅读 715评论 0 1
  • (一)Java部分 1、列举出JAVA中6个比较常用的包【天威诚信面试题】 【参考答案】 java.lang;ja...
    独云阅读 7,066评论 0 62
  • 一个人 现在两尺的阳台 夏天的夜来的得都晚些 等风来赶走这白天的残留的酷暑 一个凉爽的夜晚 天空中的那些白云,哦,...
    zhanzhan不自喜阅读 287评论 0 1