1.Map概述

Map与Collection并列存在。用来保存具有映射关系的数据:Key-Value

Map 中的 key 和  value都能够是不论什么引用类型的数据
Map 中的 key 用Set来存放。不同意反复,所以Map中的Set类型须要重写hashCode()和equals()方法,由于引用对象是通过这两个方法来保证Set的唯一性。
Map中的key 和 value之间存在单向一对一关系,即通过指定的key总能找到唯一的、确定的 value。


LinkedHashMap用一个链表维护加入进Map的顺序,遍历得到的顺序和加入顺序一致。

2.Map中的主要方法

package org.tizen.test;

import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set; import org.junit.Test; /*
*
Object put(Object key,Object value) 向Map中加入一个key以及value
Object remove(Object key) 删除制定的 key以及相应的value,即删除制定的key-value对
void putAll(Map t)
void clear()
Object get(Object key) 获取制定的key的value值,如无。返回null
boolean containsKey(Object key)
boolean containsValue(Object value)
int size()
boolean isEmpty()
boolean equals(Object obj) */
public class TestMain { @Test  
    public void TestMapAPI()  
    {
//遍历得到的顺序和加入顺序不一致
Map map = new HashMap<>();
        map.put("image", "/opt/image.jpg");
        map.put("title", "setting");
        map.put("size", 80);
 m.put("image", "/opt/image1.jpg");//覆盖之前的map.put("image", "/opt/image.jpg");
System.out.println(map.size());//3
        System.out.println(map.get("image"));
        System.out.println(map.get("title"));
        System.out.println(map.get("size"));
        boolean b = map.containsValue("setting");   
        System.out.println(b);//true   
}
}
@Test
/*
* * 元视图操作的方法:Set keySet() Collection values() Set entrySet()
*/
public void Test2() {
Map m = new HashMap();
m.put("123a", 97);
m.put("b", 98);
m.put("AbC", 1221);
m.put(null, 1);
// 1.得到Map的KeySet,遍历
Set s = m.keySet();
System.out.println("遍历set");
for (Object o : s) {
System.out.println(o);
} // 2.遍历values
Collection c = m.values();
System.out.println("增强for循环遍历values");
for (Object o : c) {
System.out.println(o);
}
System.out.println("迭代器遍历values");
Iterator i = c.iterator();
while (i.hasNext()) {
System.out.println(i.next());
}
// 3.遍历key-value对 by 增强for循环遍历
Set entry1 = m.entrySet(); for (Object o : entry1) {
// need cast
Map.Entry me = (Map.Entry) o;
System.out.println(me.getKey() + ":" + me.getValue());
}
// 4.遍历key-value对 by iterator
Set entrySet = m.entrySet();
Iterator iterator = entrySet.iterator();
while (iterator.hasNext()) {
Map.Entry entry2 = (Map.Entry) iterator.next();
System.out.println(entry2.getKey() + ":" + entry2.getValue());
} }

@Test
// 自然排序
public void test3() {
Map map = new LinkedHashMap();
map.put("AA", 213);
map.put("BB", 45);
map.put(123, "CC");
map.put(null, null);
map.put("AABB", 89);
Set set1 = map.keySet();
for (Object obj : set1) {
System.out.println(obj + ":" + map.get(obj));
}
}

@Test
public void test4() {
Map map = new LinkedHashMap();
map.put("AA", 213);
map.put("BB", 45);
map.put(123, "CC");
map.put(null, null); Set<Map.Entry> set = map.entrySet();
Iterator it = set.iterator();
while (it.hasNext()) {
Map.Entry m = (Map.Entry) it.next();
System.out.println(m.getKey() + " = " + m.getValue());
}
}

JavaSE Map的使用的更多相关文章

  1. JavaSE Map集合

    Map集合 在Map集合中保存的数据为一组数据,其中:一个数据为key,另外一个数据为value.而key和value具备对应的关系,在集合中它们属于一组(一对)数据.而每个key只能对应唯一的一个v ...

  2. Map-API及详解

    常用API 类别 方法 增加 put.putAll 删除 remove.removeAll.clear 查询 get 取值 entrySet.keySet.values 长度 size 判断 cont ...

  3. mybatis中的动态SQL语句

    有时候,静态的SQL语句并不能满足应用程序的需求.我们可以根据一些条件,来动态地构建 SQL语句. 例如,在Web应用程序中,有可能有一些搜索界面,需要输入一个或多个选项,然后根据这些已选择的条件去执 ...

  4. JavaSE中Map框架学习笔记

    前言:最近几天都在生病,退烧之后身体虚弱.头疼.在床上躺了几天,什么事情都干不了.接下来这段时间,要好好加快进度才好. 前面用了三篇文章的篇幅学习了Collection框架的相关内容,而Map框架相对 ...

  5. JavaSE集合(十)之Map

    前面给大家介绍了集合家族中的Collection家族,这一篇给大家分享的是集合中的另一个家族就是Map家族.以前的时候学习Map的时候没有很认真的去学习,我觉得很多东西还是不是很清楚. 这次我将总结的 ...

  6. JavaSE集合(八)之Map

    前面给大家介绍了集合家族中的Collection家族,这一篇给大家分享的是集合中的另一个家族就是Map家族.以前的时候学习Map的时候没有很认真的去学习,我觉得很多东西还是不是很清楚. 这次我将总结的 ...

  7. javaSE学习笔记(11)--- Map

    javaSE学习笔记(11)--- Map 1.Map集合 现实生活中,我们常会看到这样的一种集合:IP地址与主机名,身份证号与个人,系统用户名与系统用户对象等,这种一一对应的关系,就叫做映射.Jav ...

  8. [010] - JavaSE面试题(十):集合之Map

    第一期:Java面试 - 100题,梳理各大网站优秀面试题.大家可以跟着我一起来刷刷Java理论知识 [010] - JavaSE面试题(十):集合之Map 第1问:HashMap和HashTable ...

  9. JavaSE(十)之Map总结

    上一篇是总结了Collection接口的各种实现类,这一篇我将分享的是Map的总结,希望大家点评! 一.Map接口 1.1.为什么Collection不能满足集合的所有功能? Collection接口 ...

随机推荐

  1. Linux内核中的段属性

    #define __init __attribute__ ((__section__ (".init.text")))

  2. MIP启发式算法:爬山算法 (Hill climbing)

    本文主要记录和分享学习到的知识,算不上原创. *参考文献见链接. 本文讲述的是求解MIP问题的启发式算法中的爬山算法 (Hill climbing). 目录 前言 Hill climbing 的过程 ...

  3. 第42届亚洲区域赛青岛站(2017icpc青岛)经验总结以及一些感想

    上一次写这种东西还是天梯赛,当时打完心里也是挺激动的,然后我们队也没有去参加省赛,但是过了一段时间我还是从那里面恢复了出来.因为我当时确实还是很菜的,当时连个暴力都不会,看着自己仅过的那些百度的题目确 ...

  4. 卷积层feature map输出到文本

    本系列文章由 @yhl_leo 出品,转载请注明出处. 文章链接: http://blog.csdn.net/yhl_leo/article/details/52166388 以VGG_16的网络为例 ...

  5. ASP.NET(二):Application、Session和Server对象

    导读:在上篇博客中,总结了:Reques对象和Response对象的区别,以及IsPostBack属性的用法.其中说明Asp.net有6大对象,那么,这次就介绍剩下的3个对象,分别是:Applicat ...

  6. POJ 1971-Parallelogram Counting,暴力1063ms!

    Parallelogram Counting 刚学hash还不会用,看到5000ms的时限于是想着暴力来一发应该可以过.以前做过类似的题,求平行四边形个数,好像是在CF上做的,但忘了时限是多少了,方法 ...

  7. 九度oj 题目1137:浮点数加法

    题目描述: 求2个浮点数相加的和 题目中输入输出中出现浮点数都有如下的形式:P1P2...Pi.Q1Q2...Qj对于整数部分,P1P2...Pi是一个非负整数 对于小数部分,Qj不等于0 输入: 对 ...

  8. ICMP TYPE CODE

    TYPE CODE Description Query Error 0 0 Echo Reply——回显应答(Ping应答) x   3 0 Network Unreachable——网络不可达   ...

  9. BZOJ 3518 点组计数 ——莫比乌斯反演

    要求$ans=\sum_{i=1}^n \sum_{j=1}^m (n-i)(m-j)(gcd(i,j)-1)$ 可以看做枚举矩阵的大小,然后左下右上必须取的方案数. 这是斜率单增的情况 然后大力反演 ...

  10. [BZOJ1596] [Usaco2008 Jan]电话网络(树形DP || 贪心)

    传送门 1.树形DP #include <cstdio> #include <cstring> #include <iostream> #define N 1000 ...