接口Map<K, V>

一、Map功能

1.添加

put(K key, V value)

putAll(Map<? extends K, ? extends V>);

2.删除

clear()

remove(Object key); 返回对应的值

3.判断

containsKey(Object key)

containsValue(Object value)

isEmpty()

4.获取

get(Object key)  :不在返回null

size()

values();

-------------------------------------

重点:entrySet() 、 keySet();

map集合的两种取出方式

1.keySet : Set<K>:返回此映射中包含的键的set视图

因为Set具备迭代器,所以可以通过迭代方式取出所有的键,再通过get方法,获取每一个键对应的值。

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

map.put();

//先获取键的set集合

Set<String> ks = map.keySet();

//迭代器

Iterator<String> it = ks.iterator();

while(it.hasNext()){

String key = it.next();

String value = map.get(key);

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

}

2.entrySet:  Set<Map.Entry<K, V>>

返回此映射中包含的映射关系的Set视图

Map.Entry:将map集合中的映射关系存入到Set集合中,而这个关系的数据类型就是Map.Enty

//将Map集合中的映射关系取出,存入到Set集合

Set<Map.Entry<String, String>> entrySet = map.entrySet();

Iterator<Map.Entry<String, String>> it = entrySet.iterator();

while(it.hasNext()){

Map.Entry<String, String> me = it.next();

String key = me.getKey();

String value = me.getValue();

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

}

--------------------------------------

Entry也是一个接口,它是Map接口中的一个内部接口

Interface Map

{

public static Interface Entry{

public abstract Object getKey();

public abstract Object getValue();

}

}

class HashMap implements Map

{

class HaHa implements Map.Entry{

public Object getKey(){}

public Object getValue(){}

}

}

-------------------------------------

二、常见的小弟

Hashtable:底层是哈希表数据结构,不可以存入null,它是线程同步的(JDK1.0)  效率低

HashMap:基于哈希表的Map接口,可以使用null,它不是线程同步的。(JDK1.2)  效率高

TreeMap:基于二叉树的,可以用于键排序,不是线程同步。

Set:set底层就是使用了Map集合

三、Map Demo

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

map.put(“1”,”cc”);

sysout(map.containsKey(1));

sysout(map.remove(“1”));

map.get(“1”);//不在返回null

注意:当时HashMap的时候map.put(“abc”,null);

这样是可以的。当HashTable就不可以了。

//values()

获取map集合中所有的值。

map.values();//返回Collection<V>

Collection<String> coll = map.values();

Map接口的学习的更多相关文章

  1. Java集合Map接口与Map.Entry学习

    Java集合Map接口与Map.Entry学习 Map接口不是Collection接口的继承.Map接口用于维护键/值对(key/value pairs).该接口描述了从不重复的键到值的映射. (1) ...

  2. Java学习笔记32(集合框架六:Map接口)

    Map接口与Collection不同: Collection中的集合元素是孤立的,可理解为单身,是一个一个存进去的,称为单列集合 Map中的集合元素是成对存在的,可理解为夫妻,是一对一对存进去的,称为 ...

  3. Java学习(Map接口)

    一.概述: 我们通过查看Map接口描述,发现Map接口下的集合与Collection接口下的集合,它们存储数据的形式不同,如下图. 1. Collection中的集合,元素是孤立存在的(理解为单身), ...

  4. Java学习--list,set,Map接口使用

    list接口: 泛型:规定list中的元素的类型 /*     *      * 泛型不能使用基本数据类型(可以使用基本类型的包装类)     *      */    public void tes ...

  5. Java学习笔记——Map接口

    Map接口 Map接口 Map接口中键和值一一映射. 可以通过键来获取值. 异常 NoSuchElementException:访问的值不存在 ClassCastException:对象类型错误 Un ...

  6. Java学习:Map接口

    Map集合 Collection接口: 定义了单列集合规范 Collection<E> 每次存储一个元素 单个元素 Map接口:定义了双列集合的规范 Map<K,V> 每次存储 ...

  7. Map接口,Map.Entry,hashMap类,TreeMap类,WeakHashMap。

    Collection接口之前接触过,每次保存的对象是一个对象,但是在map中保存的是一对对象,是以key->value形式保存的. 定义: public interface Map<K,V ...

  8. Java集合之Map接口

    Map使用键值对来存储数据,将键映射到值对象,一个映射不能包含重复的键,每一个键最多只能映射到一个值.Map接口的具体实现类:HashMap,Hashtable,TreeMap,LinkedHashM ...

  9. Java集合中的Map接口

    jdk1.8.0_144 Map是Java三种集合中的一种位于java.util包中,Map作为一个接口存在定义了这种数据结构的一些基础操作,它的最终实现类有很多:HashMap.TreeMap.So ...

随机推荐

  1. A20 GPIO中断类型差别结果迥异的问题思考

    A20GPIO中断类型差别结果迥异的问题思考 最近在使用全志A20做开发时,发现在处理中断的时候,用电平触发模式,报中断比较乱,用边沿触发则很稳定,不会乱报.笔者感到比较困惑,笔者用电平触发写的cod ...

  2. java ssh

    sshj (currently best choice) https://github.com/shikhar/sshj ssh used in jenkins-ci https://github.c ...

  3. winform文件迁移工具

    服务器D盘上传的文件过多,空间剩下很少了,于是想把里面部分文件,大概几万个文件转移到E盘,做了这个小工具.先查询出要转移的文件清单,保存在一个记事本中,如下所示: 接着读取文件名,一个个移动到指定目录 ...

  4. ajax_异步交互-get/post方式

    Ajax的异步交互: 客户端向服务器端发送请求,直到服务器端进行响应,这个过程中,用户可以做任何其他事情(不等). 实现Ajax的异步交互步骤(举例说明): get方式: 1.创建XMLHttpReq ...

  5. C# 课堂总结3-语句

    一.顺序语句 二.条件,分支语句 1.if语句 关键是能够熟练运用 if的嵌套.要考虑好所有的情况. 如果说 条件是两种+情况相互对应的,那么就可以只用 if 与else .但必须要想好 每个else ...

  6. Bandwidthd+Postgresql数据库配置笔记

    Bandwidthd+Postgresql数据库配置笔记 本系列文章由ex_net(张建波)编写,转载请注明出处. http://blog.csdn.net/zjianbo/article/detai ...

  7. mysql 查询条件中文问题

    这是mysql字符编码的问题,因为mysql默认的字符编码为latin1它并不识别中文,所以在读取查询语句时会出现乱码 从而使查询条件不正确所以我们只需要更改它的字符编码就可以一般都是用utf8 这里 ...

  8. hdu 2815 Mod Tree 高次方程,n不为素数

    Accepted 406MS 8576K 2379 B C++/** 这里加了一点限制,,大体还是一样的,, **/ #include <iostream> #include <cs ...

  9. widget intent重复问题

    今天在做android widget时发现点击任意widget时只会更新最后一个widget 原来是requestCode的问题 Intent intent = new Intent(WidgetPr ...

  10. LintCode-两个字符串是变位词

    题目描述: 写出一个函数 anagram(s, t) 去判断两个字符串是否是颠倒字母顺序构成的 样例 给出 s="abcd",t="dcab",返回 true ...