• Java基础之集合Collection一:


    集合类 Collection
    ----------------------------------------------------------------------
    为什么出现集合类?
    面向对象语言对事物的体现都是以对象的形式,所以为了方便对多个对象的操作,就对对象进行存储,集合就是存储对象最常用 的一种方式。

    数组和集合类同是容器,有何不同?
    数组虽然也可以存储对象,但长度是固定的;集合长度是可变的。
    数组中可以存储基本数据类开,集合只能存储对象。

    集合类的特点
    集合只用于存储对象,集合长度是可变的,集合可以存储不同类型的对象。


    集合框架
    -----------------------------------------------------------------------
    Collection
     List:元素是有序的,元素可以重复。因为该集合体系有索引。
      ArrayList:底层的数据结构是数组数据结构,特点:查询速度快,增加、删除稍慢。
      LinkedList:底层使用的是链表数据结构,特点:增加、删除速度快,查询速度稍慢。
      Vector:底层是数组数据结构,线程同步。在JDK1.2后被ArrayList替代。
     Set:元素是无序的(存入和取出的顺序不一定一致),元素不可以重复;Set集合的功能和Collection是一致的。
      HashSet:底层数据结构是哈希表,线程不同步。
      TreeSet:底层数据结构是二叉书,可以对Set集合中的元素进行排序。

    #######################################################################
    为什么会出现这么多容器?

    因为每一个容器对数据的存储方式都有不同。
    这个存储方式称之为:数据结构。

    什么是迭代器?
    其实就是从集合中取出元素的方式。
    #######################################################################
    迭代器
    -----------------------------------------------------------------------
    把取出方式定义在集合的内部,这样取出方式就可以直接访问集合内部的元素,因为取出方式就被定义成了内部类。
    而每一个容器的数据结构不同,所以取出动作的细节也不同,但是都有共性内内容(判断和取出)。那么可以将这些共性抽取。

    这些内部类都符合一个规则(Iterator)。集合对外提供一个 iterator();方法,以便于获取集合取出的对象。

    第一种书写方式:
    Iterator iterator = ArrayList.iterator();
    while(iterator.hasNext())
    {
     Object obj = iterator.next();
    }

    第二种书定方式(对内存有更好的节约性,当for循环结束后,对象iterator会自动被回收):
    for(Iterator iterator = ArrayList.iterator();iterator.hasNext())
    {
     Object obj = iterator.next();
    }
    ########################################################################
    List:特有方法,凡是可以操作角标的方法都是该体系的特有方法。

    增:
       add(index,element);
       addAll(index,Collection);

    删:
        remove(index);

    改:
        set(index,element);

    查:
        get(index);
        subList(from,to); List list = ArrayList.subList(1,2);
        listIterator();
        List集合特有的迭代器, ListIterator是Iterator的子接口。
        在迭代时,不可以通过集合对象的方法操作集合中的元素,因为会发生ConcurrentModificationException异常。
       
        所以在迭代时,只能用迭代器的方法操作元素,可是Iterator方法是有限的,只能对元素进行判断、取出和删除操作。
        如果想要其它操作如:添加、修改等,就需要使用其子接口(ListIterator)。该接口只能通过List.listIterator()获取。
        ListIterator li = List.listIterator();
    ########################################################################
    Vector中特有的枚举方式:
    枚举和迭代器很像,其实枚举和迭代是一样的,只因为枚举的名称以及方法的名称都过长,所以被迭代器取代了,枚举郁郁而终。
    ########################################################################
    LinkedList:特有方法

    addFirst();
    addLast();
    被以下方法所替代(JDK1.6)
    offerFirst();
    offerLast();

    获取元素,但不删除元素,会出现NoSuchElementException
    getFirst();
    getLast();
    被以下方法所替代(JDK1.6)。获取但不删除元素,如果元素不存在,则返回null
    pollFirst();
    pollLast();

    获取元素,同时删除元素,会出现NoSuchElementException
    removeFirst();
    removeLast();
    被以下方法所替代(JDK1.6),获取同时删除元素,如果元素不存在,则返回null
    peekFirst();
    peekLast();
    ########################################################################
    hashSet如何保证元素的唯一性?
    通过元素的两个方法,hashCode和equals来完成。
    如果元素的HashCode值相同,则继续判断equals是否为true
    如果元素的HashCode值不同,则不会判断equals

    注意:对于判断元素是否存在,以及删除等操作,依赖的方法是元素的hashCode和equals方法。
    ########################################################################
    TreeSet排序

    第一种方式:
    让元素自身具备比较性,元素实现Comparable接口,并重写compareTo方法,这种方式称之为“自然顺序”或“默认顺序”

    第二种方式:
    当元素自身不具备比较性,或者元素自身具备的比较性不是所需要的,此时需要让集合自身具备比较性。
    定义比较器,即将实现了Comparator接口的对象做为参数传递给TreeSet的构造函数。

    当两种排序都在在时,以比较器为主!!!ble

    注意:在排序时,如果主要条件相同,一定要判断一下次要条件,否则会由于元素重复不被添加。

    TreeSet如何保证元素的唯一性?
    通过元素的compareTo方法return 0为依据。

  • 相关阅读:
    RabbitMQ安装
    windows下安装Erlang
    利用StopWatch类监控Java代码执行时间并分析性能
    HttpClinet工具类
    Javap与JVM指令
    idea全局护眼色绿豆沙
    删除注册在Eureka的服务(无效,多余)
    Steam之两个list间交集、并集、差集
    微服务与SpringCloud简介
    VS code 豆沙绿护眼主题
  • 原文地址:https://www.cnblogs.com/cxmsky/p/2864038.html
Copyright © 2020-2023  润新知