zoukankan      html  css  js  c++  java
  • Java集合框架之二

    1. Map接口

    我们通过查看Map接口描述,发现Map接口下的集合与Collection接口下的集合,它们存储数据的形式不同,如下图。

    l  Collection中的集合,元素是孤立存在的(理解为单身),向集合中存储元素采用一个个元素的方式存储。

    l  Map中的集合,元素是成对存在的(理解为夫妻)。每个元素由键与值两部分组成,通过键可以找对所对应的值。

    l  Collection中的集合称为单列集合,Map中的集合称为双列集合。

    l  需要注意的是,Map中的集合不能包含重复的键,值可以重复;每个键只能对应一个值。

    l  Map中常用的集合为HashMap集合、LinkedHashMap集合。

     

    2.   Map接口中常用集合概述

    通过查看Map接口描述,看到Map有多个子类,这里我们主要讲解常用的HashMap集合、LinkedHashMap集合。

    HashMap<K,V>:存储数据采用的哈希表结构,元素的存取顺序不能保证一致。由于要保证键的唯一、不重复,需要重写键的hashCode()方法、equals()方法。

    LinkedHashMap<K,V>:HashMap下有个子类LinkedHashMap,存储数据采用的哈希表结构+链表结构。通过链表结构可以保证元素的存取顺序一致;通过哈希表结构可以保证的键的唯一、不重复,需要重写键的hashCode()方法、equals()方法。

    注意:Map接口中的集合都有两个泛型变量<K,V>,在使用时,要为两个泛型变量赋予数据类型。两个泛型变量<K,V>的数据类型可以相同,也可以不同。

    3. Map接口中的常用方法

     

    l  put方法:将指定的键与值对应起来,并添加到集合中

    n  方法返回值为键所对应的值

    使用put方法时,若指定的键(key)在集合中没有,则没有这个键对应的值,返回null,并把指定的键值添加到集合中;

    使用put方法时,若指定的键(key)在集合中存在,则返回值为集合中键对应的值(该值为替换前的值),并把指定键所对应的值,替换成指定的新值。

    l  get方法:获取指定键(key)所对应的值(value)

    l  remove方法:根据指定的键(key)删除元素,返回被删除元素的值(value)。

     1 /**
     2  * 使用Map中的常用方法
     3  * Map的实现类HashMap
     4  * @author vanguard
     5  *
     6  */
     7 public class MapDemo {
     8     public static void main(String[] args) {
     9         function_2();
    10     }
    11     
    12     /**
    13      * 根据键,移除集合中的键值对,返回被移除之前的值
    14      * V remove(K)
    15      * 
    16      */
    17     private static void function_2() {
    18         Map<String ,Integer> map = new HashMap<String, Integer>();
    19         map.put("a", 1);
    20         map.put("b", 2);
    21         map.put("c", 3);
    22         System.out.println(map);
    23         
    24         Integer value = map.remove("a");
    25         System.out.println(value);
    26         System.out.println(map);
    27     }
    28 
    29     /**
    30      * 根据指定的键,获取对象的值
    31      * V get(K)
    32      * 如果没有这个键,返回null
    33      */
    34     private static void function_1() {
    35         Map<String ,Integer> map = new HashMap<String, Integer>();
    36         map.put("a", 1);
    37         map.put("b", 2);
    38         map.put("c", 3);
    39         
    40         Integer value = map.get("a");
    41         System.out.println(value);
    42     }
    43     
    44     /**
    45      * 将键值存储到集合中
    46      * V put(K, V) K作为键的对象,V作为值得对象
    47      * 存储的是重复的键,会将原有的值覆盖
    48      * 返回值,一般返回null
    49      * 存储重复键的时候,返回覆盖之前的值
    50      */
    51     public static void function() {
    52         //创建集合对象,HashMap,存储对象,键是字符串类型,值是整型
    53         Map<String, Integer> map = new HashMap<String, Integer>();
    54         map.put("abc", 1);
    55         Integer i = map.put("abc", 1);
    56         System.out.println(i);
    57         map.put("bcd", 2);
    58         map.put("cde", 3);
    59         
    60         System.out.println(map);
    61     }
    62 }

    4. Map集合遍历:键找值方式

    键找值方式:即通过元素中的键,获取键所对应的值

    操作步骤与图解:

            1.获取Map集合中所有的键,由于键是唯一的,所以返回一个Set集合存储所有的键

         2.遍历键的Set集合,得到每一个键

        3.根据键,获取键所对应的值

     1 /**
     2  * Map集合的遍历
     3  *    利用键获取值
     4  *    Map接口中定义方法keySet
     5  *    所有的键,存储到Set集合
     6  *  1. 调用map集合的方法keySet,所有的键存储到Set集合中
     7  *  2. 遍历Set集合,获取出Set集合中的所有元素 (Map中的键)
     8  *  3. 调用map集合方法get,通过键获取到值
     9  * @author vanguard
    10  *
    11  */
    12 public class HashDemo01 {
    13     public static void main(String[] args) {
    14         Map<String, Integer> map = new HashMap<String, Integer>();
    15         map.put("abc", 1);
    16         map.put("bcd", 2);
    17         map.put("cde", 3);
    18         System.out.println(map);
    19         
    20         //1. 调用map集合的方法keySet,所有的键存储到Set集合中
    21         Set<String> set = map.keySet();
    22         //2. 遍历Set集合,获取出Set集合中的所有元素 (Map中的键)
    23         Iterator<String> it = set.iterator();
    24         while(it.hasNext()) {
    25             String key = it.next();
    26             //3. 调用map集合方法get,通过键获取到值
    27             Integer value = map.get(key);
    28             System.out.println(key + "..." + value);
    29         }
    30         
    31         System.out.println("=====================");
    32         //利用增强for循环遍历
    33         for(String key : map.keySet()) {
    34             Integer value = map.get(key);
    35             System.out.println(key + "..." + value);
    36         }
    37     }
    38 }

    5.   Entry键值对对象

    在Map类设计时,提供了一个嵌套接口:Entry。Entry将键值对的对应关系封装成了对象。即键值对对象,这样我们在遍历Map集合时,就可以从每一个键值对(Entry)对象中获取对应的键与对应的值。

    l  Entry是Map接口中提供的一个静态内部嵌套接口。

    getKey()方法:获取Entry对象中的键

    l  getValue()方法:获取Entry对象中的值

    entrySet()方法:用于返回Map集合中所有的键值对(Entry)对象,以Set集合形式返回。

    6. Map集合遍历:键值对方式

    键值对方式:即通过集合中每个键值对(Entry)对象,获取键值对(Entry)对象中的键与值。

    操作步骤与图解:

            1.获取Map集合中,所有的键值对(Entry)对象,以Set集合形式返回。

          

         

            2.遍历包含键值对(Entry)对象的Set集合,得到每一个键值对(Entry)对象

            3.通过键值对(Entry)对象,获取Entry对象中的键与值。

             

    /**
     * Map集合获取方式
     * entrySet方法,键值对映射关系
     * 实现步骤:
     * 1. 调用Map集合方法entrySet()将集合映射关系对象存储到set集合中
     *    set<Entry <K, V>>
     * 2. 迭代遍历Set集合
     * 3. 获取出Set集合的元素,是映射关系对象
     * 4. 通过映射关系对象方法 getKey() getValue() 获取键值对
     * 
     * 创建内部类对象:外部类.内部类 变量名 = new 外部类.内部类()
     * @author vanguard
     *
     */
    public class HashDemo02 {
        public static void main(String[] args) {
            Map<String, Integer> map = new HashMap<String, Integer>();
            map.put("abc", 1);
            map.put("bcd", 2);
            map.put("cde", 3);
            System.out.println(map);
            
            //1. 调用Map集合方法entrySet()将集合映射关系对象存储到set集合中
            Set<Entry<String, Integer>> set = map.entrySet();
            //2. 迭代遍历Set集合
            Iterator<Entry<String, Integer>> it = set.iterator();
            while(it.hasNext()) {
                //3. 获取出Set集合的元素,是映射关系对象
                Entry<String, Integer> entry = it.next();
                //4. 通过映射关系对象方法 getKey() getValue() 获取键值对
                String key = entry.getKey();
                Integer value = entry.getValue();
                System.out.println(key + "..." + value);
            }
            
            System.out.println("==================");
            //利用增强for循环
            for(Entry<String, Integer> entry : map.entrySet()) {
                String key = entry.getKey();
                Integer value = entry.getValue();
                System.out.println(key + "..." + value);
            }
        }
    }

    7. Collections集合工具类

    Collections是集合工具类,用来对集合进行操作。部分方法如下:

       public static <T> void sort(List<T> list) // 集合元素排序

    //排序前元素list集合元素 [33,11,77,55]

    Collections.sort( list );

    //排序后元素list集合元素 [11,33,55,77]

     

      public static void shuffle(List<?> list) //  集合元素存储位置打乱

    //list集合元素 [11,33,55,77]

    Collections.shuffle( list );

    //使用shuffle方法后,集合中的元素为[77,33,11,55],每次执行该方法,集合中存储的元素位置都会随机打乱

  • 相关阅读:
    聊聊ES6中的generator
    generator-yield到底是个啥
    jquery 常用方法中那些我不知道的事
    jquery 获取textarea文本值详解
    数组去重
    五指棋人机大战之ai篇
    五指棋人机大战之ui篇
    css控制背景图像不随滚动条的滚动而滚动
    用canvas画会旋转的伞
    CSS3 实现太极图案
  • 原文地址:https://www.cnblogs.com/guodong-wang/p/7202588.html
Copyright © 2011-2022 走看看