美文网首页
2018-07-19 二、Collection及Map接口:

2018-07-19 二、Collection及Map接口:

作者: 云亦蓝 | 来源:发表于2018-07-25 10:54 被阅读0次

    (一)Collection接口

    1.collection接口

    Collection接口是Set,Queue,List的父接口。
    Collection接口中定义了多种方法可供其子类进行实现,以实现数据操作

    Collection方法有:添加元素,删除元素,返回Collection集合的个数以及清空集合等。其中重点iterator()方法,该方法的返回值是Iterator。

    1.1使用Iterator遍历集合元素

    Iterator接口经常被称作迭代器,它是Collection接口的父接口。但Iterator主要用于 遍历集合中的元素。 Iterator接口中主要定义了2个方法:
    hasNext():如果仍有元素迭代,则返回true
    has():返回迭代的下一个元素

    List<MyObject>  list    =   new ArrayList<>();
    Iterator<MyObject>  iterator    =   list.iterator();
    

    集合元素的值传给了迭代变量,仅仅传递了对象引用。保存的仅仅是指向对象内存空间的地址

    2.Set集合

    Set集合与Collection集合基本相同,没有提供任何额外的方法

    Set集合不允许包含相同的元素,如果试图把两个相同的元素加入同一个Set集合 中,则添加操作失败,add()方法返回false,且新元素不会被加入。

    3..List集合

    • List集合代表一个元素有序可重复的集合,集合中每个元素都有其对应的顺序索引。
    • List集合默认按元素的添加顺序设置元素的索引,例如第一个添加的元素索引为0,第二 个添加的元素索引为1......

    List作为Collection接口的子接口,可以使用Collection接口里的全部方法。而且由于 List是有序集合,因此List集合里增加了一些根据索引来操作集合元素的方法。

    void add(int index, Object element): 在列表的指定位置插入指定元素(可选 操作)。
    boolean addAll(int index, Collection<? extends E> c) : 将集合c 中的所有 元素都插入到列表中的指定位置index处。
    Object get(index): 返回列表中指定位置的元素。
    int indexOf(Object o): 返回此列表中第一次出现的指定元素的索引;如果此列 表不包含该元素,则返回 -1。
    int lastIndexOf(Object o): 返回此列表中最后出现的指定元素的索引;如果列 表不包含此元素,则返回 -1。
    Object remove(int index): 移除列表中指定位置的元素。
    Object set(int index, Object element): 用指定元素替换列表中指定位置的元 素。
    List subList(int fromIndex, int toIndex): 返回列表中指定的 fromIndex(包 括 )和 toIndex(不包括)之间的所有集合元素组成的子集。 Object[] toArray(): 返回按适当顺序包含列表中的所有元素的数组(从第一个 元素到最后一个元素)
    void replaceAll(UnaryOperator operator): 根据operator指定的计算规则重新 设置List集合的所有元素。
    void sort(Comparator c): 根据Comparator参数对List集合的元素排序。

    4.Queue集合

    • 队列通常是指“先进先出”(FIFO,first-in-firstout)的容器。
    • 队列的头部是在队列中存放时间最长的元素,队列的尾部是保存在队 列中存放时间最短的元素。
    • 新元素插入(offer)到队列的尾部,访问元素(poll) 操作会返回队列头部的元素并移除(peak()获取但不移除)。
    • 通常,队列不允许随机访问队列中的元素。

    (二)Map接口

    • Map用户保存具有映射关系的数据。因此Map集合里保存着两组数,一组值用户保 存Map里的key,另一组值用户保存Map里的value,
    • key和value都可以是任何引用类 型的数据。Map的key不允许重复,即同一个Map对象的任何两个key通过equals方 法比较总是返回false。

    2.Map集合与Set集合、List集合的关系

    • 与Set集合的关系
      把Map里的所有key就组成了一个Set集合(所有的key没有 顺序,key与key之间不能重复),实际上Map确实包含了一个keySet()方法,用户 返回Map里所有key组成的Set集合。
    • 与List集合的关系
      把Map里的所有value放在一起来看,它们又非常类似于一个List:元素与元素 之间可以重复,每个元素可以根据索引来查找,只是Map中索引不再使用整数值, 而是以另外一个对象作为索引。

    Map集合最典型的用法

    • 成对地添加、删除key-value对,
    • 判断该Map中 是否包含指定key,是否包含指定value
    • 可以通过Map提供的keySet()方法获取 所有key组成的集合,然后使用foreach循环来遍历Map的所有key,根据key即可遍 历所有的value
    public class Hello {
        public  static  void    main(String[]   args){      
            Day day1    =   new Day(1,  2,  3);             
            Day day2    =   new Day(2,  3,  4);                 
            Map<String,Day> map =   new HashMap<String,Day>();          
            //成对放入key-value对                            
            map.put("第一个",  day1);                      
            map.put("第二个",  day2);                      
            //判断是否包含指定的key                          
            System.out.println(map.containsKey("第一个")); 
            //判断是否包含指定的value                            
            System.out.println(map.containsValue(day1));        
            //循环遍历                              
            //1.获得Map中所有key组成的set集合             
            Set<String> keySet  =   map.keySet();               
            //2.使用foreach进行遍历                       
            for (String key :   keySet) {                   
                //根据key获得指定的value               
                System.out.println(map.get(key));               
                }                               
            //根据key来移除key-value对    
            map.remove("第一个");                          
            System.out.println(map);                
            }
            
    }
    
    
    

    相关文章

      网友评论

          本文标题:2018-07-19 二、Collection及Map接口:

          本文链接:https://www.haomeiwen.com/subject/osyzpftx.html