第19章 集合框架(3)-Map接口

1.Map接口概述

Map是一种映射关系,那么什么是映射关系呢?

映射的数学解释

设A,B是两个非空集合,如果存在一个法则,使得对A中的每一个元素a,按法则f,在B中有唯一确定的元素b与之对应,则称f为A到B的映射,记作f:A-B.

映射关系(对于A,B集合)

A集合中的每一个元素都可以在B集合中找到唯一的一个值与之对应

严格上来说Map并不是集合,不属于Collection接口,而是两个集合之间的映射关系,每次存储都应该存储A集合中一个元素(Key),B集合中一个元素(Value),我们还是习惯把Map也称之为集合

因为Map接口并没有继承于Collection接口,也没有继承Iterable接口,所以不能直接对Map使用for-each操作,但是如果遍历的话,可以使用Map里面的一些特殊的方法来操作。

存储过程中,key值不能重复,遵循Set集合,Value允许重复,遵循List集合

2.Map中的常用操作方法

Map是一个接口,此类型的常用方法以HashMap类为例,大部分都是通用的,如果需要特别的方法,可以查询api

3.Set和Map之间的关系

Map和Set中有很多相类似的实现类名:

如果集合前缀相同,说明底层算法是一样的,现在单独使用HashSet和hashMap来研究

通过阅读源码,发现相同算法的Set底层用的是相同算法的Map。把Set的集合对象作为Map的Key,再使用一个Object常量为value

因此,更符合我们说的在Map中,所有的key就是一个Set集合

4.Map的实现类和性能分析

Map实现类:

解释:

HashMap:采用哈希表算法,此时Map中的Key不会保证添加的先后顺序,key也不允许重复。

key判断重复的标准是:key1和key2是否equals为true,并且hashCode相等

TreeMap:采用哈希算法:采用红黑树算法,此时Map中的key会按照自然顺序或定制顺序,key也不允许重复

key判断重复的标准是:compareTo/compare的返回值是否为0

LinkedHashMap:采用链表和哈希算法,此时Map中的key会保证先后添加顺序,key不允许重复。

key判断重复的标准和HashMap中的key的标准相同

Hashtable:采用哈希表算法,是hashMap的前身(类似Vector是ArrayList的前身)

在java的集合框架之前,表示映射关系就使用Hashtable

所有的方法都是使用synchronized修饰符,线程安全的,但是性能相对HashMap较低。打死不用

Properties:Hashtable的子类,此时要求key和value都是String类型,用来加载资源文件

一般的,我们定义map,key都使用不可变的类(String等),把key作为value的唯一名称

如何选用

HashMap和TreeMap以及LinkedHashMap都是线程不安全的,但是性能很高。

解决方案Map m = Collections.synchronizedMap(Map对象);

Hashtable类实现线程安全,但是性能低

哈希算法作等值查询最快

树结构算法,作范围查询最快,应用到索引上

5.Map案例(计算字符中字符出现的次数)

import java.util.HashMap;
import java.util.Map; /**
* 计算一个字符串中,每一个字符出现的次数
*/
public class StringCount {
public static void main(String[] args) {
String str = "aqazasawsawsaws";
//把字符串转换为char数组(字符串本质就是char[])
char[] arr = str.toCharArray();
//key:存储字符名,value:存储出现次数
Map<Character, Integer> map = new HashMap<>();
//循环得到每一个字符
for (char ch:arr){
//判断当前字符是否在Map中的key存在
if (map.containsKey(ch)){
//当前Map的key包含该字符,此时取出该value,自增再存进去
Integer old = map.get(ch);
map.put(ch, old+1);
}else {
//当前Map的key不包含该字符,把该字符存到Map中,设置value为1
map.put(ch,1);
}
}
System.out.println(map);//{a=6, q=1, s=4, w=3, z=1}
}
}

6.List和Set以及Map的选用

选用哪一种容器取决于每一种容器的存储特点以及当前业务的需求

List:单一元素集合

允许元素重复/记录元素的添加顺序

Set单一元素集合

不允许元素重复/不及录元素的添加顺序

既要不重复,又要保证先后顺序,可以使用:LinkedHashSet

Map:双元素集合,如果存储数据的时候,还得给数据起一个名称时,此时考虑使用Map

List, Set, Map之间的相互转换:

List<String> list = new ArrayList<>();

把List转换为Set:

Set<String> set = new HashSet<>(list);

把Set转换为List:

List<String> list2 = new ArrayList<>(set);

Map不能直接转换为List或Set,但是Map中的方法可以间接转换

7.List和Map的综合应用

Map在以后运用的非常广泛,比如可以表示javaBean对象,可以作缓存

javaBean对象:多对,属性名=属性值

Map对象;每一个key-value就好比一对属性名=属性值

把Map对象转换为javaBean对象,把javaBean对象转换为Map对象

Set,List,Map三种集合并不都是单独使用的,偶尔也会综合使用

示例:

public class StudentTest {
public static void main(String[] args) {
//使用Set集合存储一个班级学生的名称
Set<String> name1 = new HashSet<>();
name1.add("赵一");
name1.add("李二");
name1.add("张三");
System.out.println(name1);//[李二, 张三, 赵一] Set<String> name2 = new HashSet<>();
name2.add("西门大官人");
name2.add("叶孤城");
name2.add("陆小凤"); //使用Map来存储多个班级的学生
Map<String, Set<String>> classMap = new HashMap<>();
classMap.put("初出茅庐",name1);
classMap.put("登堂入室",name2);
System.out.println(classMap);
//{登堂入室=[西门大官人, 陆小凤, 叶孤城], 初出茅庐=[李二, 张三, 赵一]} Map<String, Set<String>> classMap2 = new HashMap<>();
classMap2.put("初出茅庐",name1);
classMap2.put("登堂入室",name2); //使用List来存储所有学院的学生姓名
List<Map<String ,Set<String>>> school = new ArrayList<>();
school.add(classMap);
school.add(classMap2);
System.out.println(school);
//[{登堂入室=[西门大官人, 陆小凤, 叶孤城], 初出茅庐=[李二, 张三, 赵一]}, {登堂入室=[西门大官人, 陆小凤, 叶孤城], 初出茅庐=[李二, 张三, 赵一]}] }
}

第19章 集合框架(3)-Map接口的更多相关文章

  1. 第18章 集合框架(2)-Set接口

    第18章 集合框架(2)-Set接口 Set是Collection子接口,模拟了数学上的集的概念 Set集合存储特点 1.不允许元素重复 2.不会记录元素的先后添加顺序 Set只包含从Collecti ...

  2. Java集合框架之Map接口浅析

    Java集合框架之Map接口浅析 一.Map接口综述: 1.1java.util.Map<k, v>简介 位于java.util包下的Map接口,是Java集合框架的重要成员,它是和Col ...

  3. Java集合框架中Map接口的使用

    在我们常用的Java集合框架接口中,除了前面说过的Collection接口以及他的根接口List接口和Set接口的使用,Map接口也是一个经常使用的接口,和Collection接口不同,Map接口并不 ...

  4. 集合框架之Map接口

    Map是将键映射到值的对象.一个映射不能包含重复的键:每个键最多只能映射到一个值. Map 接口提供三种collection视图,允许以键集.值集或键-值映射关系集的形式查看某个映射的内容.映射顺序定 ...

  5. JAVA基础第五章-集合框架Map篇

    业内经常说的一句话是不要重复造轮子,但是有时候,只有自己造一个轮子了,才会深刻明白什么样的轮子适合山路,什么样的轮子适合平地! 我将会持续更新java基础知识,欢迎关注. 往期章节: JAVA基础第一 ...

  6. Java使用实现面向对象编程:第七章集合框架的解读=>重中之重

    对于集合框架,是非常重要的知识,是程序员必须要知道的知识点. 但是我们为什么要引入集合框架呢? 我们之前用过数组存储数据,但是采用数组存储存在了很多的缺陷.而现在我们引用了集合框架,可以完全弥补了数组 ...

  7. Java集合框架之Collection接口

    Java是一门面向对象的语言,那么我们写程序的时候最经常操作的便是对象了,为此,Java提供了一些专门用来处理对象的类库,这些类库的集合我们称之为集合框架.Java集合工具包位于Java.util包下 ...

  8. Java集合框架之四大接口、常用实现类

    Java集合框架 <Java集合框架的四大接口> Collection:存储无序的.不唯一的数据:其下有List和Set两大接口. List:存储有序的.不唯一的数据: Set:存储无序的 ...

  9. Java集合框架之Set接口浅析

    Java集合框架之Set接口浅析 一.java.util.Set接口综述: 这里只对Set接口做一简单综述,其具体实现类的分析,朋友们可关注我后续的博文 1.1Set接口简介 java.util.se ...

随机推荐

  1. 背水一战 Windows 10 (12) - 绘图: Shape, Path

    [源码下载] 背水一战 Windows 10 (12) - 绘图: Shape, Path 作者:webabcd 介绍背水一战 Windows 10 之 绘图 Shape - 图形 Path - 路径 ...

  2. js设置、获取单值cookie和多值cookie

    js设置.获取单值cookie和多值cookie,代码如下: var CookieUtil = (function () { var Cookie = function () { // 获取单值coo ...

  3. Java新人学习(li)

    一.项目中搭配使用SVN和Git 安装SVN:安装熟悉Git:安装maven,修改setting.xml文件:安装eclipse,配置jdk.maven路径: 建立自己的Git仓库,熟悉常用的Git命 ...

  4. win7下 VirtualBox虚拟机开机后台自启动

    win7下安装个linux虚拟机,学习下非常好. 但是每次使用linux的时候,都是打开virtualBox-->启动安装的linux系统-->再用远程桌面(SSH等)连接 每次手动打开比 ...

  5. 【新技术】Docker 学习笔记

    原文地址 一.Docker 简介 Docker 两个主要部件: Docker: 开源的容器虚拟化平台 Docker Hub: 用于分享.管理 Docker 容器的 Docker SaaS 平台 --  ...

  6. 如何寻找“真爱”型合伙人

          曾与朋友笑侃,现在找人结婚,跟合伙开公司差不多,各自条件一一对比,细细斟酌,最后双方达成一致,才得凑成一对冤家.谁说不是呢?两种关系都实为"伙伴",开公司重" ...

  7. B-Tree索引在sqlserver和mysql中的应用

    在谈论数据库性能优化的时候,通常都会提到“索引”,但很多人其实并没有真正理解索引,也没有搞清楚索引为什么就能加快检索速度,以至于在实践中并不能很好的应用索引.事实上,索引是一种廉价而且十分有效的优化手 ...

  8. javascript执行环境(执行期上下文)详解

    javascript执行环境(执行期上下文) 当js控制器(control)进入可执行代码时,控制器会进入一个执行环境,活动的多个执行环境构成执行环境栈,最上面的是正在运行的执行环境,当控制器进入一个 ...

  9. CSS字符编码引起乱码

    乱码引起的CSS失效原理:     由于一个中文是两个字符组成,在编码不一致的情况下会引发字符的“重新”组合,(半个汉字的编码字符与后面的字符组合生成新的“文字”)引发原本的结束符合“变异”,从而导致 ...

  10. 一个有趣的CM

    系统 : Windows xp 程序 : Crackme#3 - Self Destructed 程序下载地址 :http://pan.baidu.com/s/1kVxwlaZ 要求 : 注册机编写 ...