Map是一种把键对象和值对象进行关联的容器,而一个值对象又可以是一个Map,依次类推,这样就可形成一个多级映射。

这里有详细的论述http://www.oracle.com/technetwork/cn/articles/maps1-100947-zhs.html

map.put("x","y");

map.get("x") == y

就是一一映射关系,每个key对应一个value 知道了key也就知道了value

对于键对象来说,像Set 一样,一个Map容器中的键对象不允许重复,为了保持查找结果的一致性;如果有两个键对象一样,键对象对应的值对象时就无法确定了,造成混乱,所以键的唯一性很重要。当然在使用过程中,某个键所对应的值对象可能会发生变 化,这时会按照最后一次修改的值对象与键对应。

值对象没有唯一性的要求。你可以将任意多个键都映射到一个值对象上,这不会发生任何问题(不过使用上可能会造成不便,你不知道你得到的到底是那一个键所对应的值对象)。

Map有两种比较常用的实现:HashMap和TreeMap,WeakMap。

!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

HashMap 用哈希码快速定位一个键,但是元素存储无序。注意:其put()函数支持null,而如果原位置上有值,则替换为新值后,并返回旧值。其返回过程确定的位置正是get()函数的实现。参见http://blog.csdn.net/longshenlmj/article/details/17077869

而TreeMap则是对键按序存放,因此有扩展的方法,比如firstKey(),lastKey() 等,你还可以从TreeMap中指定一个范围以取得其子Map。

键和值的关联很简单,用put(Object key,Object value)方法即可将一个键与一个值对象相关联。用get(Object key)可得到与此key对象所对应的值对象,WeakMap这个用于内存自动释放的。

!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

官方的非官方的Map事先有好几百个(hibernate、spring、apache等都有实现)。官方的主要用到的就三大类:HashMap(最常见的,内部无序的)、TreeMap(排过序的)及WeakMap(这个用于内存自动释放的);还有一类是多线程时使用的并发Map。

如需查看具体Map子类。装个Eclipse,ctrl+shit+t输入Map后,在Map的class名那里按ctrl+T可以查看到Map所有的实现类。

使用时,都用HasMap等实现Map接口的类

创建:Map<String,String> map = new HashMap<String,String>();

插入元素:map.put("1","a");

移除元素: map.remove("1");

清空: map.clear();

Map map=new HashMap();

map.put("name","张三");

System.out.print((String)map.get("name"));

循环输出映射:

while(itr.hasNext()){

String key=(String)itr.next();

String value=(String)map.get(key);

System.out.println("key=="+key+",value=="+value);

}

输出还有其它用法:把map看成一个Map.Entry的Set,那么每个Map.Entry就是一个键--值对,遍历这个Set,直接从中获取key和value。

Map map = new HashMap();

Iterator it = map.entrySet().iterator();

while (it.hasNext()) {

Map.Entry entry = (Map.Entry) it.next();

Object key = entry.getKey();

Object value = entry.getValue();

System.out.println(“key”+key+“:value”+value);

}

其中,中间生成一个set

// Get a set of the entries

Set set = map.entrySet();

// Get an iterator

Iterator i = set.iterator();

// Display elements

JDK1.5中,应用新特性For-Each循环:

Map m = new HashMap();

for(Object o : map.keySet()){

map.get(o);

}

返回的 set 中的每个元素都是一个 Map.Entry 类型。



private Hashtable<String, String> emails = new Hashtable<String, String>();



//方法一: 用entrySet()

Iterator it = emails.entrySet().iterator();

while(it.hasNext()){

Map.Entry m=(Map.Entry)it.next();

logger.info("email-" + m.getKey() + ":" + m.getValue());

}



// 方法二:jdk1.5支持,用entrySet()和For-Each循环()

for (Map.Entry<String, String> m : emails.entrySet()) {



logger.info("email-" + m.getKey() + ":" + m.getValue());

}



// 方法三:用keySet()

Iterator it = emails.keySet().iterator();

while (it.hasNext()){

String key;

key=(String)it.next();

logger.info("email-" + key + ":" + emails.get(key));

}



// 方法五:jdk1.5支持,用keySEt()和For-Each循环



for(Object m: emails.keySet()){

logger.info("email-" + m+ ":" + emails.get(m));

}



另外 我们可以先把hashMap 转为集合Collection,再迭代输出,不过得到的对象



Map aa = new HashMap();

aa.put("tmp1", new Object()); //追加 替换用同样的函数.

aa.remove("temp1"); //删除

for (Iterator i = aa.values().iterator(); i.hasNext(); ) {

Object temp = i.next();

} //遍历



例子,包含TreeSet的元素内部排序的



public static void main(String[] args) {

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

HashMap<Object,Object> hash = new HashMap<Object,Object>();

TreeMap<Object,Object> treeMap = new TreeMap<Object,Object>();

list.add("a");

list.add("b");

list.add("c");



hash.put(3, 3);

hash.put(4, 4);

hash.put(5, 5);

hash.put(6, 6);

hash.put(1, 1);

hash.put(2, 2);



treeMap.put(1, 1);

treeMap.put(2, 2);

treeMap.put(3, 3);

treeMap.put(4, 4);

treeMap.put(5, 5);

treeMap.put(6, 6);



//list遍历

for(String m: list){

System.out.println(m);

}

// hashmap entrySet() 遍历

for(Map.Entry<Object,Object> m: hash.entrySet()){

System.out.println(m.getKey()+"---"+m.getValue());

}

//hashmap keySet() 遍历

for(Object m: hash.keySet()){

System.out.println(m+"---"+hash.get(m));

}

// treemap keySet()遍历

for(Object m: treeMap.keySet()){

System.out.println(m+"---"+treeMap.get(m));

}

}

java的map的更多相关文章

  1. 错误:java.util.Map is an interface, and JAXB can't handle interfaces.

    问题: 在整合spring+cxf时报错java.util.Map is an interface, and JAXB can't handle interfaces. 解决方法: 将服务端的serv ...

  2. Java中Map常用方法总结以及遍历方式的汇总

    一.整理: 看到array,就要想到角标. 看到link,就要想到first,last. 看到hash,就要想到hashCode,equals. 看到tree,就要想到两个接口.Comparable, ...

  3. Java 基础 Map 练习题

    第一题 (Map)利用Map,完成下面的功能: 从命令行读入一个字符串,表示一个年份,输出该年的世界杯冠军是哪支球队.如果该 年没有举办世界杯,则输出:没有举办世界杯. 附:世界杯冠军以及对应的夺冠年 ...

  4. java 遍历map 方法 集合 五种的方法

    package com.jackey.topic; import java.util.ArrayList;import java.util.HashMap;import java.util.Itera ...

  5. JAVA/Android Map与String的转换方法

    在Android开发中 Map与String的转换在,在一些需求中经常用到,使用net.sf.json.JSONObject.fromObject可以方便的将string转为Map.但需要导入jar包 ...

  6. java中map插入相同的key

    测试用例: package test; import org.junit.Test; import po.Person; import java.util.HashMap; import java.u ...

  7. JAVA ,Map接口 ,迭代器Iterator

    1.    Map 接口概述 java.util.Map 接口描述了映射结构, Map 接口允许以键集.值集合或键 - 值映射关系集的形式查看某个映射的内容. Java 自带了各种 Map 类. 这些 ...

  8. jmap命令(Java Memory Map)(转)

    JDK内置工具使用 一.javah命令(C Header and Stub File Generator) 二.jps命令(Java Virtual Machine Process Status To ...

  9. Java遍历Map的3种方式

    package test; import java.util.Collection; import java.util.HashMap; import java.util.Map; import ja ...

  10. 【Java】Map杂谈,hashcode()、equals()、HashMap、TreeMap、LinkedHashMap、ConcurrentHashMap

    参考的优秀文章: <Java编程思想>第四版 <Effective Java>第二版 Map接口是映射表的结构,维护键对象与值对象的对应关系,称键值对. > hashco ...

随机推荐

  1. JavaScript原型与原型链

    一.数据类型 JavaScript的数据类型可以分为基本数据类型和引用数据类型. 基本数据类型(6种) String Number Boolean null undefined Symbol(ES6) ...

  2. 无忧代理免费ip爬取(端口js加密)

    起因 为了训练爬虫技能(其实主要还是js技能-),翻了可能有反爬的网站挨个摧残,现在轮到这个网站了:http://www.data5u.com/free/index.shtml 解密过程 打开网站,在 ...

  3. JVM初探- 使用堆外内存减少Full GC

    JVM初探-使用堆外内存减少Full GC 标签 : JVM 问题: 大部分主流互联网企业线上Server JVM选用了CMS收集器(如Taobao.LinkedIn.Vdian), 虽然CMS可与用 ...

  4. Python 2.7 闭包的局限

    想法源自:http://stackoverflow.com/questions/141642/what-limitations-have-closures-in-python-compared-to- ...

  5. 安卓高级8 SurfaceView (1)

    文章转载:http://www.cnblogs.com/xuling/archive/2011/06/06/android.html 首先我们先来看下官方API对SurfaceView的介绍 Surf ...

  6. Android开发技巧——Camera拍照功能

    本篇是我对开发项目的拍照功能过程中,对Camera拍照使用的总结.由于camera2是在api level 21(5.0.1)才引入的,而Camera到6.0仍可使用,所以暂未考虑camera2. 文 ...

  7. Android桌面小插件——Widget

    Android桌面小插件--Widget 效果图 实现 1. 创建Widget类 创建一个Widget类,并实现页面创建的时候,就实现显示时间 package com.kongqw.kqwwidget ...

  8. XListView下拉刷新和上拉加载更多详解

    转载本专栏每一篇博客请注明转载出处地址,尊重原创.博客链接地址:小杨的博客 http://blog.csdn.net/qq_32059827/article/details/53167655 市面上有 ...

  9. 在一维坐标轴上有n个区间段,求重合区间最长的两个区间段。

    //重叠区间数 #define N 2 typedef struct arrange { int x; int y; } Arrange; //先按左边界排序,若相等再按右边界排序(升序) int c ...

  10. 2014 BDTC 参会有感

    中国大数据技术大会(Big Data Technology Conference,BDTC)是目前国内最具影响.规模最大的大数据领域的技术盛会.大会的前身是Hadoop中国云计算大会(Hadoop i ...