1:Map
(1)将键映射到值的对象。

一个映射不能包含重复的键;每个键最多只能映射到一个值。

键值对的方式存在
(2)Map和Collection的区别?

A:Map 存储的是键值对形式的元素,键唯一,值可以重复。夫妻对
    B:Collection 存储的是单独出现的元素,子接口Set元素唯一,子接口List元素可重复。光棍
(3)Map接口功能概述
A:添加功能   put();
B:删除功能   remove(key);
C:判断功能

containsKey(key);判断是否包含key键

containsValue(value);判断是否包含值
D:获取功能

get(key);

values();

E:长度功能

size();
(4)Map集合的遍历
   A:键找值
      a:获取所有键的集合
      b:遍历键的集合,得到每一个键
      c:根据键到集合中去找值

  B:键值对对象找键和值
      a:获取所有的键值对对象的集合
      b:遍历键值对对象的集合,获取每一个键值对对象
      c:根据键值对对象去获取键和值
hashMap 无序唯一
代码体现:
Map<String,String> hm = new HashMap<String,String>();

hm.put("it002","hello");
hm.put("it003","world");
hm.put("it001","java");

//方式1 键找值
Set<String> set = hm.keySet();
for(String key : set) {
String value = hm.get(key);
System.out.println(key+"---"+value);
}

//方式2 键值对对象找键和值
Set<Map.Entry<String,String>> set2 = hm.entrySet();
for(Map.Entry<String,String> me : set2) {
String key = me.getKey();
String value = me.getValue();
System.out.println(key+"---"+value);
}
(5)案例
A:统计一个字符串中每个字符出现的次数

String str="abcdefabcdefabcdef";

//将字符串转化为字符数组
char[] c=str.toCharArray();

//创建map集合
Map<String,Integer> map=new LinkedHashMap<String,Integer>();

//遍历字符数组
for (int i = 0; i < c.length; i++)
{
/*已经存在
* 给value加一
* 不存在
* 给集合key值
* */
if (map.containsKey(String.valueOf(c[i])))
{
//修改
map.put(String.valueOf(c[i]),map.get(String.valueOf(c[i]))+1);
}
else{
map.put(String.valueOf(c[i]),1);
}
}
//方法一
Set<Map.Entry<String,Integer>> set=map.entrySet();
for (Map.Entry<String,Integer> mapkey : set)
{
System.out.println(mapkey);
}

B:集合的嵌套遍历

a:多层嵌套

Map<String,LinkedHashMap<Integer,LinkedHashMap<Integer,String>>> map=new LinkedHashMap<String,LinkedHashMap<Integer,LinkedHashMap<Integer,String>>>();

LinkedHashMap<Integer,String> map2=new LinkedHashMap<Integer,String>();
LinkedHashMap<Integer,LinkedHashMap<Integer,String>> map1=new LinkedHashMap<Integer,LinkedHashMap<Integer,String>>();
map.put("1", map1);
map1.put(1, map2);
map2.put(1, "str");
Set<Map.Entry<String,LinkedHashMap<Integer,LinkedHashMap<Integer,String>>>> set=map.entrySet();
Set<Entry<Integer,LinkedHashMap<Integer,String>>> set2 = map1.entrySet();
Set<Entry<Integer,String>> set3 = map2.entrySet();
for (Map.Entry<String,LinkedHashMap<Integer,LinkedHashMap<Integer,String>>> mapkey : set)
{System.out.println(mapkey);
for (Entry<Integer, LinkedHashMap<Integer, String>> map1key : set2)
{System.out.println(map1key);
for (Entry<Integer, String> map2key : set3)
{
System.out.println(map2key);
}
}

}

输出结果:

1={1={1=str}}
1={1=str}
1=str

TreeMap  有序唯一

TreeMap<Integer,String> map=new TreeMap<Integer, String>(new Comparator() {
@Override
public int compare(Object o1, Object o2) {
return -1;
}
});
map.put(1, "str");
map.put(2, "str");
map.put(4, "str");
map.put(3, "str");
map.put(5, "str");
Set<Entry<Integer,String>> set = map.entrySet();
for (Entry<Integer, String> map2key : set)
{
System.out.println(map2key);
}

输出:

5=str
3=str
4=str
2=str
1=str

默认排序是升序,加上比较器会按照自己的方式进行排序

Map集合的更多相关文章

  1. Java版本:识别Json字符串并分隔成Map集合

    前言: 最近又看了点Java的知识,于是想着把CYQ.Data V5迁移到Java版本. 过程发现坑很多,理论上看大部分很相似,实践上代码写起来发现大部分都要重新思考方案. 遇到的C#转Java的一些 ...

  2. Java常用的几种集合, Map集合,Set集合,List集合

    Java中  Object是所有类的根 Java集合常用的集合List集合.Set集合.Map集合 Map接口常用的一些方法 size() 获取集合中名值对的数量 put(key k, value v ...

  3. MyBatis的一系列问题的处理(遍历Map集合和智能标签和属性和字段不一样的解决办法 和sql片段)(三)

    一.字段名与属性名(数据库的名字)不一样怎么办? 方案一:在小配置中配置一个resultMapper <!--方案一:resultMapper 字段名与属性名不一致 --> <res ...

  4. Map集合及与Collection的区别、HashMap和HashTable的区别、Collections、

    特点:将键映射到值的对象,一个映射不能包含重复的键,每个键最多只能映射到一个值. Map集合和Collection集合的区别 Map集合:成对出现 (情侣)                       ...

  5. java://Comparator、Comparable的用法(按照要求将map集合的键值对进行顺序输出)

    import java.util.*; public class Person implements Comparable<Person>//使Person的属性具有比较性 { priva ...

  6. Java集合类学习笔记(Map集合)

    Map用于保存具有映射关系的数据,因此Map集合里保存着两组数据,一组用于保存Map的key,一组用于保存key所对应的value. Map的key不允许重复. HashMap和Hashtable都是 ...

  7. java学习第18天(map集合)

    Map集合是将键映射到值的对象.一个映射不能包含重复的键:每个键最多只能映射到一个值. 存储的是键值对形式的元素,键唯一,值可以重复,有点类似于数据库中的主键加数据.主要功能有: A:添加功能 put ...

  8. Map集合 总结

    (本人第一次写博客,部分内容有参照李刚老师的疯狂java系列图书,如有遗漏错误,请多指教,谢谢.) Java的集合类可分为Set.List.Map.Queue,其中Set.List.Queue都有共同 ...

  9. Map集合的应用及其遍历方式

    ---> HashMap :底层基于哈希表      存储原理也使用哈希表来存放的:            往HashMap添加了元素 ,首先会调用键的hashCode方法 获得一个哈希值,然后 ...

随机推荐

  1. linux拷贝命令,移动命令

    http://blog.sina.com.cn/s/blog_7479f7990101089d.html

  2. Windos环境用Nginx配置反向代理和负载均衡

    Windos环境用Nginx配置反向代理和负载均衡 引言:在前后端分离架构下,难免会遇到跨域问题.目前的解决方案大致有JSONP,反向代理,CORS这三种方式.JSONP兼容性良好,最大的缺点是只支持 ...

  3. git多账号登录问题

    作者:白狼 出处:http://www.manks.top/git-multiply-accounts.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文 ...

  4. SqlServer简单数据分页

    手边开发的后端项目一直以来都用的.NET MVC框架,访问数据库使用其自带的EF CodeFirst模式,写存储过程的能力都快退化了 闲来无事,自己写了条分页存储过程,网上类似的文章多的是,这里只列了 ...

  5. Linux基础介绍【第二篇】

    远程连接Linux的原理 SHH远程连接介绍 当前,在几乎所有的互联网企业环境中,最常用的Linux提供远程连接服务的工具就是SSH软件,SSH分为SSH客户端和SSH服务端两部分.其中,SSH服务端 ...

  6. s:form标签

    2017-01-07 17:43:18 基本的用法 <!-- Action类必须有一个无参的构造器,因为在执行action方法之前,拦截器已经创建了一个"空"的Action对 ...

  7. 绿色版的Linux.NET——“Jws.Mono”(续)

    在前一篇文章中,我们简略的介绍了jws.mono的安装使用,以及我们如何自己动手做一个jws.mono出来. 在文章发表之后的几天里,我一直觉得有点不妥之处,直到后来猛然的意识到:我们自己动手做的jw ...

  8. Visual Studio 2015正式发布

    Windows 10 RTM正式版要7月29日发布,微软的另一个重磅软件Visual Studio 2015已经率先发布,今天如期放出了正式版本.Visual Studio 2015包括许多新功能和更 ...

  9. 细说SSO单点登录

    什么是SSO? 如果你已知道,请略过本节! SSO核心意义就一句话:一处登录,处处登录:一处注销,处处注销.即:在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统. 很多人容易把SS ...

  10. .NET中使用Redis

    Redis是一个用的比较广泛的Key/Value的内存数据库,新浪微博.Github.StackOverflow 等大型应用中都用其作为缓存,Redis的官网为http://redis.io/. 最近 ...