zoukankan      html  css  js  c++  java
  • jah老师中关于集合的总结

    --------概述:
    1、Java 集合就像一种容器,可以把多个对象的引用放入容器中
    2、Java 集合类可以用于存储数量不等的多个对象,还可用于保存具有映射关系的关联数组
    3、Java 集合可分为 Set、List 和 Map 三种体系
    Set:无序、不可重复的集合
    List:有序,可重复的集合 Map:具有映射关系的集合


    --------Collection 接口
    Collection 接口是 List、Set 和 Queue 接口的父接口,该接口里定义的方法既可用于操作 Set 集合,也可用于操作 List 和 Queue 集合:

    --------使用 Iterator 接口遍历集合元素
    1、主要用于遍历 Collection 集合中的元素
    Iterator 对象也被称为迭代器
    2、隐藏了各种 Collection 实现类的底层细节
    向应用程序提供了遍历 Collection 集合元素的统一编程接口
    3、Iterator 仅用于遍历集合
    Iterator 本身并不提供承装对象的能力。
    如果需要创建Iterator 对象,则必须有一个被迭代的集合。

    --------使用 foreach 循环遍历集合元素
    for(Person p:persons){
    System.out.println(p);
    }


    --------Set 集合1、Set 集合不允许包含相同的元素 如果试图把两个相同的元素加入同一个 Set 集合中,则添加操作失败。(不报错)2、使用equals(),比较Set是否相同 Set 判断两个对象是否相同不是使用 == 运算符,而是根据 equals 方法
    --------HashSet1、HashSet 是 Set 接口的典型实现 大多数时候使用 Set 集合时都使用这个实现类。
    2、HashSet 按 Hash 算法来存储集合中的元素 因此具有很好的存取和查找性能。3、HashSet 具有以下特点:
    不能保证元素的排列顺序 HashSet 不是线程安全的 集合元素可以使用 null

    --------TreeSetTreeSet 是 SortedSet 接口的实现类,TreeSet 可以确保集合元素处于排序状态。


    --------List
    1、代表一个元素有序的集合
    集合中的每个元素都有其对应的顺序索引
    2、允许使用重复元素
    可以通过索引来访问指定位置的集合元素。3、默认按元素的添加顺序设置元素的索引
    4、 根据索引来操作集合元素的方法

    --------ArrayList 和 Vector(了解)ArrayList 和 Vector 是 List 接口的两个典型实现区别:
    Vector是一个古老的集合,通常建议使用 ArrayList
    ArrayList 是线程不安全的,而 Vector 是线程安全的。
    即使为保证 List 集合线程安全,也不推荐使用 Vector
    --------Map1、用于保存具有映射关系的数据 Map 集合里保存着两组值,一组值用于保存 Map 里的 Key,另外一组用于保存 Map 里的 Value
    2、key 和 value 都可以是任何引用类型的数据
    3、Key 不允许重复4、Key 和 Value 之间存在单向一对一关系
    即通过指定的 Key 总能找到唯一的,确定的 Value。

    --------

    --------TreeMapTreeMap 存储 Key-Value 对时
    需要根据 Key 对 key-value 对进行排序。
    可以保证所有的 Key-Value 对处于有序状态。

    TreeMap 的 Key 的排序: 自然排序: TreeMap 的所有的 Key 必须实现 Comparable 接口,而且所有的 Key 应该是同一个类的对象,否则将会抛出 ClasssCastException 定制排序: 创建 TreeMap 时,传入一个 Comparator 对象,该对象负责对 TreeMap 中的所有 key 进行排序。此时不需要 Map 的 Key 实现 Comparable 接口
    --------

  • 相关阅读:
    【prufer编码】BZOJ1430 小猴打架
    【费马小定理】BZOJ3260 跳
    【欧拉函数】BZOJ2705: [SDOI2012]Longge的问题
    【卡特兰数】BZOJ1485: [HNOI2009]有趣的数列
    【缩点+拓扑判链】POJ2762 Going from u to v or from v to u?
    【Floyd】BZOJ1491: [NOI2007]社交网络
    【转】对信息学竞赛中调试方法的建议
    【建图+拓扑判环】BZOJ3953: [WF2013]Self-Assembly
    【dfs判负环】BZOJ1489: [HNOI2009]最小圈
    【二分+最小树形图】UVA11865 比赛网络
  • 原文地址:https://www.cnblogs.com/1020182600HENG/p/6709501.html
Copyright © 2011-2022 走看看