JAVA之旅(二十二)——Map概述,子类对象特点,共性方法,keySet,entrySet,Map小练习…

释放双眼,带上耳机,听听看~!

JAVA之旅(二十二)——Map概述,子类对象特点,共性方法,keySet,entrySet,Map小练习


继续坚持下去吧,各位骚年们!

事实上,我们的数据结构,只剩下这个Map的知识点了,平时开发中,也是能看到他的,所以还是非常值得去学习的一个知识点的,我们直接开车了

一.Map概述

泛型< k,v> 键值对,映射关系

基本特点

  • 该集合存储键值对,是一对一对往里存,而且要保证键的唯一性

  • 1.添加

  • put(key ,values)
    * putAll()

    • 2.删除
  • clear()
    * remove(object key)

    • 3.判断
  • containsValue(Object value)
    * containsKey(Object key)
    * isEmpty()

    • 4.获取
  • get(Object key)
    * size()
    * values()
    * entrySet()
    * keySet()

我们的学习步骤也是这样来的,

二.子类对象特点

Map有三个子类

  • Hashtable

  • 底层是哈希表数据结构,不可以存入null值或者键,该集合是线程同步的

  • HashMap

  • 底层是哈希表数据结构,允许使用null的键值对,线程是不同步的。效率高

  • TreeMap

  • 底层是二叉树数据结构,线程不同步,可以用于给map集合中的键进行排序

Map和Set很像,其实Set底层就是使用了Map集合

三.共性方法

我们看一下他们的共同点


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
1package com.lgl.hellojava;
2
3import java.util.Collection;
4import java.util.HashMap;
5import java.util.Map;
6
7public class HelloJJAVA {
8    public static void main(String[] args) {
9        Map&lt;String, String&gt; map = new HashMap&lt;String, String&gt;();
10
11        // 添加元素
12        map.put(&quot;001&quot;, &quot;zhangsan&quot;);
13        map.put(&quot;002&quot;, &quot;lisi&quot;);
14        map.put(&quot;003&quot;, &quot;wangwu&quot;);
15
16        System.out.println(&quot;原数据:&quot;+map);
17
18        // 判断是否存在002的key
19        System.out.println(map.containsKey(&quot;002&quot;));
20        //刪除
21        System.out.println(map.remove(&quot;002&quot;));
22        System.out.println(&quot;删除后:&quot;+map);
23
24        //获取
25        System.out.println(&quot;获取:&quot;+map.get(&quot;001&quot;));
26
27        //可以通过get方法的返回值来判断一个键是否存在
28        map.put(null, &quot;haha&quot;);
29        System.out.println(&quot;null:&quot;+map);
30
31        //获取map集合中所有的值
32        Collection&lt;String&gt; values = map.values();
33        System.out.println(&quot;map的值:&quot;+values);
34    }
35}
36

这里可以看到输出的结果

但是这里要注意的是,添加元素,如果添加的时候,相同的键,那么后面的,会被后添加的覆盖原有的键对应的值,并put方法会返回被覆盖的值

四.keySet

想取出他的值,他并没有迭代器,那我们的思路可以转变一下拿到他的所有的键再去get不就可以拿到键值对了,我们来看一下

  • keySet

  • 将map中所有的值存入到Set集合中,因为Set具备迭代器,所有可以迭代方法取出的所有的键,根据get方法,获取每一个键对应的值


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
1package com.lgl.hellojava;
2
3import java.util.HashMap;
4import java.util.Iterator;
5import java.util.Map;
6import java.util.Set;
7
8public class HelloJJAVA {
9    public static void main(String[] args) {
10        Map&lt;String, String&gt; map = new HashMap&lt;String, String&gt;();
11
12        map.put(&quot;001&quot;, &quot;zhangsan&quot;);
13        map.put(&quot;002&quot;, &quot;lisi&quot;);
14        map.put(&quot;003&quot;, &quot;wangwu&quot;);
15
16        // 先获取map集合中的所有键的Set集合
17        Set&lt;String&gt; keySet = map.keySet();
18
19        // 有了Set集合就可以获取迭代器
20        Iterator&lt;String&gt; iterator = keySet.iterator();
21
22        while (iterator.hasNext()) {
23            String string = iterator.next();
24            // 有了键可以通过map集合的get方法获取其对应的值
25            String value = map.get(string);
26            System.out.println(&quot;key:&quot; + string + &quot;values:&quot; + value);
27
28        }
29
30    }
31}
32

这种方法还是比较好理解的,对吧,但是这样比较麻烦,我们来看另一种

五.entrySet


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
1package com.lgl.hellojava;
2
3import java.util.HashMap;
4import java.util.Iterator;
5import java.util.Map;
6import java.util.Map.Entry;
7import java.util.Set;
8
9public class HelloJJAVA {
10    public static void main(String[] args) {
11        Map&lt;String, String&gt; map = new HashMap&lt;String, String&gt;();
12
13        map.put(&quot;001&quot;, &quot;zhangsan&quot;);
14        map.put(&quot;002&quot;, &quot;lisi&quot;);
15        map.put(&quot;003&quot;, &quot;wangwu&quot;);
16
17        // 将map集合中的映射关系取出,存入到Set集合中
18        Set&lt;Entry&lt;String, String&gt;&gt; entrySet = map.entrySet();
19
20        Iterator&lt;Entry&lt;String, String&gt;&gt; iterator = entrySet.iterator();
21
22        while (iterator.hasNext()) {
23            Map.Entry&lt;String, String&gt; entry = iterator.next();
24            System.out.println(entry.getKey() + &quot;:&quot; + entry.getValue());
25        }
26    }
27}
28

定义泛型虽然比较麻烦,但是取出来还是比较简单的,原理是什么?其实我们可以写一段伪代码来说明的


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
1package com.lgl.hello;
2
3public class HashMap implements Map {
4
5    class Hahs implements Map.Entry {
6
7        @Override
8        public Object getKey() {
9            // TODO Auto-generated method stub
10            return null;
11        }
12
13        @Override
14        public Object getValue() {
15            // TODO Auto-generated method stub
16            return null;
17        }
18
19    }
20}
21
22interface Map {
23    public static interface Entry {
24        public abstract Object getKey();
25
26        public abstract Object getValue();
27    }
28}
29

父子接口,直接访问,内部规则

六.Map小练习

我们可以通过一个小练习来学习一下使用规则,而需求,我直接写在注释上


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
1package com.lgl.hellojava;
2
3import java.util.HashMap;
4import java.util.Iterator;
5import java.util.Map.Entry;
6import java.util.Set;
7
8public class HelloJJAVA {
9    public static void main(String[] args) {
10        /**
11         * 每个学生都有对应的归属地 学生Student,地址String 学生属性:姓名和年龄
12         * 注意:姓名和年龄相同的视为同一个学生,保证学生的唯一性
13         *
14         * 1.描述学生 2.定义Map容器,将学生作为键,地址作为值存入 3.获取Map容器中的元素
15         */
16        HashMap&lt;Student, String&gt; hm = new HashMap&lt;Student, String&gt;();
17
18        hm.put(new Student(&quot;zhangsan&quot;, 15), &quot;beijing&quot;);
19        hm.put(new Student(&quot;lisi&quot;, 16), &quot;shanghai&quot;);
20        hm.put(new Student(&quot;wangwu&quot;, 17), &quot;guangzhou&quot;);
21        hm.put(new Student(&quot;liliu&quot;, 10), &quot;shenzhen&quot;);
22
23        // 第一种取出方式keySet
24        Set&lt;Student&gt; keySet = hm.keySet();
25        Iterator&lt;Student&gt; iterator = keySet.iterator();
26        while (iterator.hasNext()) {
27            Student student = iterator.next();
28            String addr = hm.get(student);
29            System.out.println(student + &quot;:&quot; + addr);
30        }
31
32        //第二种取出方式 entrySet
33        Set&lt;Entry&lt;Student, String&gt;&gt; entrySet = hm.entrySet();
34        Iterator&lt;Entry&lt;Student, String&gt;&gt; iterator2 = entrySet.iterator();
35        while (iterator2.hasNext()) {
36            Entry&lt;Student, String&gt; next = iterator2.next();
37            System.out.println(next.getKey()+&quot;:&quot;+next.getValue());
38        }
39    }
40}
41
42/**
43 * 描述学生
44 *
45 * @author LGL
46 *
47 */
48class Student implements Comparable&lt;Student&gt; {
49
50    private String name;
51    private int age;
52
53    public Student(String name, int age) {
54        this.name = name;
55        this.age = age;
56    }
57
58    @Override
59    public int hashCode() {
60        // TODO Auto-generated method stub
61        return name.hashCode() + age * 34;
62    }
63
64    @Override
65    public boolean equals(Object obj) {
66        if (!(obj instanceof Student))
67            throw new RuntimeException(&quot;类型不匹配&quot;);
68        Student s = (Student) obj;
69        return this.name.equals(s.name) &amp;&amp; this.age == s.age;
70    }
71
72    public String getName() {
73        return name;
74    }
75
76    public void setName(String name) {
77        this.name = name;
78    }
79
80    public int getAge() {
81        return age;
82    }
83
84    public void setAge(int age) {
85        this.age = age;
86    }
87
88    @Override
89    public int compareTo(Student s) {
90        int num = new Integer(this.age).compareTo(new Integer(s.age));
91        if (num == 0)
92            return this.name.compareTo(s.name);
93        return num;
94    }
95}
96

OK,例子就是用两种取出的方式罢了,相信你自己也一定能做好的,好的,我们本节课到这里也就结束了,下节再见

有兴趣的话,加下群:555974449

给TA打赏
共{{data.count}}人
人已打赏
安全技术

bootstrap栅格系统自定义列

2021-12-21 16:36:11

安全技术

从零搭建自己的SpringBoot后台框架(二十三)

2022-1-12 12:36:11

个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索