Map的主要实现类:

  --HashMap:Map的主要实现类(掌握)

  --LinkedHashMap:使用链表维护添加进Map中的顺序,遍历时按添加时的顺序遍历

  --TreeMap:按照添加进Map中的元素key的制定属性进行排序。(了解)、

  --Hashtable 古老的实现类不建议使用

    --Properties:常来处理属性文件,键和值都是String类型(掌握)

常用方法(不加泛型)

Map map = new HashMap<>();

//Object put(Object key,Object value) 向Map中添加一个元素

map.put("A",123);

map.put("B",456);

map.put("C",789);

//Object remove(Object key) 按照制定为key删除一条记录

map.remove("C");

//void putAll(Map t) 将t中的全部记录加入当前Map集合中

Map t = new HashMap<>();

t.put("D",741);

map.putAll(t);

//void clear() 清空Map中的记录

t.clear();

//Object get(Object key) 获取制定key值对应的value值,如果没有此key值则返回null

Object value = map.get("A");

//boolean containsKey(Object key) 是否包含key

boolean flag1 = map.containsKey("A");

//boolean containsValue(Object value) 是否包含value

boolean flag2 = map.containsValue("B");

//int size() 返回当前Map的长度

System.out.println(map.size());

//boolean isEmpty() 判断当前Map集合是否为空

System.out.println(map.isEmpty());

HashMap

1、Key使用Set集合存放,Key不可重复

2、Value使用Collection存放,可以重复

3、一个Key-Value对是一个Entry,Entry用Set存放不可重复。

4、向HashMap添加一个Key-Value记录,会调用Key所在类的equals()方法,判断Map中是否已存在相同Key的记录,如果有则覆盖之前的记录,存放最后一次存放的Key-Value记录

Map的遍历

一、遍历Key集

Set key = map.keySet();

for(Object obj:key){

  System.out.println(obj);

}

二、遍历Value集

Collection values = map.values();

Iterator iterator = values.iterator();

while(iterator.hasNext()){

  Syetem.out.println(iterator.next());

}

三、遍历key-value对

方式一、先遍历key集,再根据指定key得到对应value值

Set key = map.keySet();

for(Object obj:key){

  System.out.println(obj+"-"+map.get(obj));

}

方式二、通过Entry遍历

Set set2 = map.entrySet();

for(Object obj:set2){

  Map.Entry entry = (Entry)obj;

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

}

方式三、

for(Object entry:map.entrySet()){

  Map.Entry et = (Entry) entry;

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

}

使用Properties处理属性文件

public void testMap3() throws IOException{
  Properties properties = new Properties();
  // 加载属性文件
  properties.load(TestMap.class.getResourceAsStream("/jdbc.properties"));
  // 获取用户名和密码
  String user = properties.getProperty("user");
  String password = properties.getProperty("password");
  
  System.out.println(user);
  System.out.println(password);
 }

集合框架四(Map)的更多相关文章

  1. Java集合框架之map

    Java集合框架之map. Map的主要实现类有HashMap,LinkedHashMap,TreeMap,等等.具体可参阅API文档. 其中HashMap是无序排序. LinkedHashMap是自 ...

  2. 第19章 集合框架(3)-Map接口

    第19章 集合框架(3)-Map接口 1.Map接口概述 Map是一种映射关系,那么什么是映射关系呢? 映射的数学解释 设A,B是两个非空集合,如果存在一个法则,使得对A中的每一个元素a,按法则f,在 ...

  3. Java集合框架之Map接口浅析

    Java集合框架之Map接口浅析 一.Map接口综述: 1.1java.util.Map<k, v>简介 位于java.util包下的Map接口,是Java集合框架的重要成员,它是和Col ...

  4. Java中的集合(十四) Map的实现类LinkedHashMap

    Java中的集合(十四) Map的实现类LinkedHashMap 一.LinkedHashMap的简介 LinkedHashMap是Map接口的实现类,继承了HashMap,它通过重写父类相关的方法 ...

  5. 【JAVA集合框架之Map】

    一.概述.1.Map是一种接口,在JAVA集合框架中是以一种非常重要的集合.2.Map一次添加一对元素,所以又称为“双列集合”(Collection一次添加一个元素,所以又称为“单列集合”)3.Map ...

  6. 浅谈集合框架四——集合扩展:集合循环输出方式及list输出方式的效率对比

    最近刚学完集合框架,想把自己的一些学习笔记与想法整理一下,所以本篇博客或许会有一些内容写的不严谨或者不正确,还请大神指出.初学者对于本篇博客只建议作为参考,欢迎留言共同学习. 之前有介绍集合框架的体系 ...

  7. 十七、Java基础---------集合框架之Map

    前两篇文章中介绍了Collection框架,今天来介绍一下Map集合,并用综合事例来演示. Map<K,V> Map<K,V>:Map存储的是键值对形式的元素,它的每一个元素, ...

  8. Java集合框架中Map接口的使用

    在我们常用的Java集合框架接口中,除了前面说过的Collection接口以及他的根接口List接口和Set接口的使用,Map接口也是一个经常使用的接口,和Collection接口不同,Map接口并不 ...

  9. Java集合框架(四)

    Collections    集合框架的工具类    着重讲解以下方法: 1.sort(): 1º根据元素的自然顺序对指定列表按升序进行排序,列表中的所有元素都必须实现comparable接口. pu ...

  10. [黑马程序员] 集合框架2——Map系 & 集合工具类(Collections、Arrays)

    ---------------------- ASP.Net+Android+IO开发..Net培训.期待与您交流! ---------------------- 0. 集合框架按其所实现的接口, 大 ...

随机推荐

  1. [ActionScript 3.0] as3处理xml的功能和遍历节点

    as3比as2处理xml的功能增强了N倍,获取或遍历节点非常之方便,类似于json对像的处理方式. XML 的一个强大功能是它能够通过文本字符的线性字符串提供复杂的嵌套数据.将数据加载到 XML 对象 ...

  2. gulp 打包错误 TypeError: Path must be string. Received undefined

    Running gulp gives “path.js:7 throw new TypeError('Path must be a string. Received ' + inspect(path) ...

  3. JavaScript getter和setter

    对象的属性是由属性名name,值key,和其他特性(可读写性 writable,可枚举性enumerable,可配置性configurable)组成的.从ES5开发,提供了getter和setter ...

  4. hander消息机制原理(looper轮询监听机制)

    基本原理 线程中调用Handler.sendMsg()方法(参数是Message对象),将需要Main线程处理的事件 添加到Main线程的MessageQueue中,Main线程通过MainLoope ...

  5. 线程同步辅助类CyclicBarrier

    CyclicBarrier 是一个可重置的多路同步点,在某些并行编程风格中很有用. 集合点同步:CyclicBarrier 多条线程同时执行一个阶段性任务时,相互等待,等到最后一个线程执行完阶段后,才 ...

  6. ES配置文件中文版

    ##################### Elasticsearch Configuration Example ##################### # This file contains ...

  7. configure: error: You need a C++ compiler for C++ support.[系统缺少c++环境]

    一.错误configure: error: You need a C++ compiler for C++ support.二.安装c++ compiler情况1.当您的服务器能链接网络时候[联网安装 ...

  8. web的脚本安全-CSRF

    CSRF,即Cross-site request forgery,中文一般叫跨站请求伪造. 攻击原理是,用户在A网站(登录,之后打开一个B网站,B网站的脚本(或HTML标签)向A网站发送一个请求,这个 ...

  9. Java 中的队列 Queue

    一.队列的定义 我们都知道队列(Queue)是一种先进先出(FIFO)的数据结构,Java中定义了java.util.Queue接口用来表示队列.Java中的Queue与List.Set属于同一个级别 ...

  10. 记一次解决CSS定位bug思路

    事因 网站中的遮罩层大都有一个问题,就是在这个遮罩层中滑动,里面的内容也会跟着滑动,我是这样想的,既然都有这个问题,干脆写一个通用的插件出来,省的每个还得单独处理.如果是单独处理这个问题是比较好解决的 ...