接口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. POJ 3450 Corporate Identity(KMP)

    [题目链接] http://poj.org/problem?id=3450 [题目大意] 求k个字符串的最长公共子串,如果有多个答案,则输出字典序最小的. [题解] 我们对第一个串的每一个后缀和其余所 ...

  2. Paths on a Grid(规律)

    Paths on a Grid Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 23270   Accepted: 5735 ...

  3. ubuntu 14.04设备flash媒体播放器

    今天是2014年4一个月19日本,就在两天前公布 ubuntu 14.04版本号, 以今天的优势是星期六,西安小雨,所以折腾linux. 我是个有点linux基础的小白.说是有些基础是由于以前在上大学 ...

  4. linux select 网络模型

    io模型: 同步IO: 阻塞形式,非阻塞形式(轮询).信号驱动IO.IO复用(select, poll, epoll): 异步io:aio_read() 典型场景: 1.客户端处理多种IO------ ...

  5. BootStrap 智能表单系列 八 表单配置json详解

    本章属于该系列的高级部分,将介绍表单中一些列的配置 1.config列的配置: 主要用于控制布局 :config:{autoLayout:true|'1,2,2,4'} true:根据配置项最里层的数 ...

  6. .net-一般处理程序及生命周期

    IsReusable属性用来表示在IHttpHandlerFactory对象创建IHttpHandler的时候是否能够将这个Handler存入池中以便重用. 一般处理程序(HttpHandler):是 ...

  7. zoj 1109 zoj 1109 Language of FatMouse(字典树)

    好开心,手动自己按照字典树的思想用c写了一个优化后的trie字典树,就是用链表来代替26个大小的字符数组.完全按照自己按照自己的想法打的,没有参考如何被人的代码.调试了一天,居然最后错在一个小问题上, ...

  8. 日志记录Filter

    Filter也可以日志记录,在request 之前后, 该filter 使用Apache 日只记录工具,记录客户IP ,访问URI 以及消耗时间. LogFilter.java package com ...

  9. eclipse集成jetty开发web项目(不采用maven方式)

    以前开发过程部署项目都是采用tomcat,偶然发现jetty,所以试了下,挺方便的,直切主题. 1.下载jetty,楼主使用的jetty8,地址http://download.eclipse.org/ ...

  10. php分页实例附代码

    一个典型的PHP分页实例代码分享,学习php的朋友肯定用得到,主要是了解思路: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transit ...