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

这里可以看到输出的结果

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

四.keySet

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

  • keySet

    • 将map中所有的值存入到Set集合中,因为Set具备迭代器,所有可以迭代方法取出的所有的键,根据get方法,获取每一个键对应的值
  1. package com.lgl.hellojava;
  2. import java.util.HashMap;
  3. import java.util.Iterator;
  4. import java.util.Map;
  5. import java.util.Set;
  6. public class HelloJJAVA {
  7. public static void main(String[] args) {
  8. Map<String, String> map = new HashMap<String, String>();
  9. map.put("001", "zhangsan");
  10. map.put("002", "lisi");
  11. map.put("003", "wangwu");
  12. // 先获取map集合中的所有键的Set集合
  13. Set<String> keySet = map.keySet();
  14. // 有了Set集合就可以获取迭代器
  15. Iterator<String> iterator = keySet.iterator();
  16. while (iterator.hasNext()) {
  17. String string = iterator.next();
  18. // 有了键可以通过map集合的get方法获取其对应的值
  19. String value = map.get(string);
  20. System.out.println("key:" + string + "values:" + value);
  21. }
  22. }
  23. }

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

五.entrySet

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

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

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

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

六.Map小练习

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

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

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

有兴趣的话,加下群:555974449

JAVA之旅(二十二)——Map概述,子类对象特点,共性方法,keySet,entrySet,Map小练习的更多相关文章

  1. JAVA之旅(十二)——Thread,run和start的特点,线程运行状态,获取线程对象和名称,多线程实例演示,使用Runnable接口

    JAVA之旅(十二)--Thread,run和start的特点,线程运行状态,获取线程对象和名称,多线程实例演示,使用Runnable接口 开始挑战一些难度了,线程和I/O方面的操作了,继续坚持 一. ...

  2. Java中的集合(十二) 实现Map接口的WeakHashMap

    Java中的集合(十二) 实现Map接口的WeakHashMap 一.WeakHashMap简介 WeakHashMap和HashMap一样,WeakHashMap也是一个哈希表,存储的也是键值对(k ...

  3. JAVA之旅(十)——异常的概述,Try-Catch,异常声明Throws,多异常处理,自定义异常,Throw和Throws的区别

    JAVA之旅(十)--异常的概述,Try-Catch,异常声明Throws,多异常处理,自定义异常,Throw和Throws的区别 不知不觉,JAVA之旅这个系列已经更新到第十篇了,感觉如梦如幻,时间 ...

  4. 201871010104-陈园园 《面向对象程序设计(java)》第十二周学习总结

    201871010104-陈园园 <面向对象程序设计(java)>第十二周学习总结 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ ...

  5. 201871010105-曹玉中《面向对象程序设计(java)》第十二周学习总结

    201871010105-曹玉中<面向对象程序设计(java)>第十二周学习总结 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ ...

  6. 201871010136-赵艳强《面向对象程序设计(java)》第十二周学习总结

    201871010136-赵艳强<面向对象程序设计(java)>第十二周学习总结   项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh ...

  7. 201871020225-牟星源《面向对象程序设计(java)》第十二周学习总结

    201871020225-牟星源<面向对象程序设计(java)>第十二周学习总结 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ ...

  8. JAVA基础知识总结:一到二十二全部总结

    >一: 一.软件开发的常识 1.什么是软件? 一系列按照特定顺序组织起来的计算机数据或者指令 常见的软件: 系统软件:Windows\Mac OS \Linux 应用软件:QQ,一系列的播放器( ...

  9. 201871010123-吴丽丽《面向对象程序设计(Java)》第十二周学习总结

    201871010123-吴丽丽<面向对象程序设计(Java)>第十二周学习总结 项目 内容 这个作业属于哪个课程  https://www.cnblogs.com/nwnu-daizh/ ...

随机推荐

  1. 40道Java初中级算法面试题

    [程序1]   题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第四个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 1.程序分析:   兔子的规律为数 ...

  2. LINUX逻辑卷(LVM)管理与逻辑卷分区

    LINUX之逻辑卷管理与逻辑卷扩展 LVM是逻辑卷管理(Logical Volume Manager)的简称,他是建立在物理存储设备之上的一个抽象层,允许你生成逻辑存储卷,和直接使用物理存储在管理上相 ...

  3. AJAX 向后台发送带 List 集合的对象

    现有基类: public class School { int name; int address; List<Student> students = new ArrayList<S ...

  4. 浏览器本地下拉框查询选择js

    首先需要引用jquery-1.7.2.js. 页面下拉框有对应的数据,此下拉框的查询将不与服务器交互.本地下拉框查询.暂不支持通过键盘上下按键和enter键控制 // JavaScript Docum ...

  5. Node.js 控制台

    稳定性: 4 - 冻结 {Object} 用于打印输出字符到 stdout 和 stderr.和多数浏览器提供的 console 对象函数一样,Node 也是输出到 stdout 和 stderr. ...

  6. Docker的名字空间

    名字空间是 Linux 内核一个强大的特性.每个容器都有自己单独的名字空间,运行在其中的应用都像是在独立的操作系统中运行一样.名字空间保证了容器之间彼此互不影响. pid 名字空间 不同用户的进程就是 ...

  7. PHP 5 Timezones

    PHP 支持的时区 下面是 PHP 支持的时区的完整列表,这些对一些 PHP 日期函数很有用. 非洲 美洲 南极洲 北冰洋 亚洲 大西洋 大洋洲 欧洲 印度洋 太平洋 非洲 Africa/Abidja ...

  8. Android RRO机制的运用-----google开机向导客制化

    上周五的时候领导分了一个任务,客户让在google开机向导里面增加一页,首先就想到了android的Overlay,然后网上搜了下,发下有很多人写了这方面的技术.而且写的都还不错,所以本篇只当记录作用 ...

  9. SpringMVC总结(SSM)

    Day1 1. springMvc:是一个表现层框架: 作用:就是从请求中接收传入的参数, 将处理后的结果数据返回给页面展示2. ssm整合: 1)Dao层 pojo和映射文件以及接口手动编写(或使用 ...

  10. django+uwsgi+nginx+postgresql备忘

    安装pg创建数据库xxx设置用户密码111111 apt-get install postgresql su - postgres psql create database xxx; alter us ...