import java.util.HashMap;

 public class MapTest {
 /**
  * 1.Map集合是双列几个,一个元素包含两个值(key,value)
  * 2.Map集合中的元素,key和value的数据类型可以相同也可以不同
  * 3.Map集合中的元素Key不可以重复,value可以重复
  * 4.Map集合中的元素,key和value一一对应
  *
  * 常用实现类:
  * java.tuil.hashMap<k,v>集合,implements Map<k,v>接口
  * 1。hashMap集合底层是哈希表,查询的速度特别快
  *             jdk1.8前:数组+单向链表
  *             jdk1.8后:数组+单项链表/红黑树
  * 2.hashMap是无序集合
  *
  * LinkedHashMap特点:
  * 1.LinkedHashMap集合迪底层是哈希表+链表
  * 2.LinkedHashMap集合是一个有序的集合,储存元素和取出元素的顺序是一致的
  *
  * 方法:
  * put(k,v):添加,返回v:key不重复返回v是null,key重复会替换value返回被替换值
  * remove(object key):把指定键对应的value删除,返回删除元素,key存在返回v,key不存在返回null
  * get(k):k存在返回value,k不存在返回null
  * containskey(k):判断是否包含k,包含返回true,不包含返回false
  */
 public static void main(String[] args) {
     HashMap<String, String> hashMap = new HashMap<>();
     String put1 = hashMap.put("杨过", "小龙女");
     String put2 = hashMap.put("冷锋", "龙小云");
     String put3 = hashMap.put("A", "B");
     System.out.println("put1:"+put1);
     System.out.println("put2:"+put2);
     System.out.println("put3:"+put3);
     System.out.println(hashMap);
     System.out.println(hashMap.get("杨过"));
     hashMap.remove("杨过");
     System.out.println(hashMap);
     System.out.println(hashMap.containsKey("杨过"));

 }
  /**
  * 遍历:
  * keySet():所有key添加到set集合中
  * 遍历set集合获取map结合中的每一个key
  * 通过getkey找到value
  */
  public static void main(String[] args) {
      HashMap<String, String> hashMap = new HashMap<>();
      String put1 = hashMap.put("杨过", "小龙女");
      String put2 = hashMap.put("冷锋", "龙小云");
      String put3 = hashMap.put("A", "B");
      Set<String> strings = hashMap.keySet();
      for (String string : strings) {
          System.out.println(hashMap.get(string));
      }
  }
  /** Entry键值对对象被:
       * 在map接口中有一个内部类接口Entry
       * 作用:当map结合一创建,就在map集合中创建一个Entry对象,用来记录键与值(键值对对象,键与值的映射关系)
       * 方法:
       * entrySet():把map集合内部的多个Entry对象取出来存储到一个Set集合中
       * getkey
       * getvalue
       */
      public static void main(String[] args){
          HashMap<String, String> hashMap = new HashMap<>();
          String put1 = hashMap.put("杨过", "小龙女");
          String put2 = hashMap.put("冷锋", "龙小云");
          String put3 = hashMap.put("A", "B");
          Set<Map.Entry<String, String>> entries = hashMap.entrySet();
          for (Map.Entry<String, String> entry : entries) {
              System.out.println(entry.getKey());
              System.out.println(entry.getValue());
          }
      }
 }
  /** hashMap:存储自定义类型键值
       * map集合保证key是唯一的:作为key元素必须重写hashCode和equals方法保证key的唯一性
       *
       * LinkedHashMap entends HashMap
       * 哈希表+链表
       * key不允许重复,有序集合
       *
       *
       * Hashtable集合 implements Map接口
       * 底层是哈希表,是线程安全的速度慢
       *Hashtable集合不能储存null值,null键
       * Hashtable和vector集合一样,在jdk1.2版本之后被先进的集合(HashMap,ArrayList)取代了
       *Hashtable的子类properties一样活跃在历史舞台
       * properties集合是一个唯一和IO流相结合的集合
       *
       * Map集合练习:
       * 需求:计算一个字符串中每个字符出现的个数
       * 1.使用Scanner获取用户输入字符串
       * 2.创建Map集合,key是字符串中的字符,value是字符个数
       * 3.遍历字符串,获取每一个字符
       * 4.使用获取到的字符去Mao集合中判断key是否存在
       *      如果存在:
       *          通过key获取value并++
       *      如果不存在:
       *          put(k,1)
       * 5.遍历集合
       *
       * jdk9对集合添加的优化:
       * list接口,Set接口,Map接口:增加一个静态的方法of,可以给集合一次添加多个元素
       * 使用前提:当几个中存储的元素的个数已经确定了,不在改变
       * 注意事项:
       *      1.of方法只适用于List接口,Set接口,Map接口,不适用于接口的实现类
       *      2.of方法的返回值是一个不能改变的集合,集合不能在使用add,put方法添加元素,会抛出异常
       *      3.Set接口和Map接口在调用of方法时不能有重复元素,否则会抛出异常
       *
       *
       */

java_Map集合的更多相关文章

  1. java基础集合经典训练题

    第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...

  2. .Net多线程编程—并发集合

    并发集合 1 为什么使用并发集合? 原因主要有以下几点: System.Collections和System.Collections.Generic名称空间中所提供的经典列表.集合和数组都不是线程安全 ...

  3. 一起学 Java(三) 集合框架、数据结构、泛型

    一.Java 集合框架 集合框架是一个用来代表和操纵集合的统一架构.所有的集合框架都包含如下内容: 接口:是代表集合的抽象数据类型.接口允许集合独立操纵其代表的细节.在面向对象的语言,接口通常形成一个 ...

  4. 编写高质量代码:改善Java程序的151个建议(第5章:数组和集合___建议75~78)

    建议75:集合中的元素必须做到compareTo和equals同步 实现了Comparable接口的元素就可以排序,compareTo方法是Comparable接口要求必须实现的,它与equals方法 ...

  5. java基础_集合List与Set接口

    List接口继承了Collection的方法  当然也有自己特有的方法向指定位置添加元素   add(索引,添加的元素); 移除指定索引的元素   remove(索引) 修改指定索引的元素   set ...

  6. Java基础Collection集合

    1.Collection是所有集合的父类,在JDK1.5之后又加入了Iterable超级类(可以不用了解) 2.学习集合从Collection开始,所有集合都继承了他的方法 集合结构如图:

  7. 轻量级“集合”迭代器-Generator

    Generator是PHP 5.5加入的新语言特性.但是,它似乎并没有被很多PHP开发者广泛采用.因此,在我们了解PHP 7对Generator的改进之前,我们先通过一个简单却显而易见的例子来了解下G ...

  8. Asp.net MVC 传递数据 从前台到后台,包括单个对象,多个对象,集合

    今天为大家分享下 Asp.net MVC 将数据从前台传递到后台的几种方式. 环境:VS2013,MVC5.0框架 1.基本数据类型 我们常见有传递 int, string, bool, double ...

  9. 这些.NET开源项目你知道吗?.NET平台开源文档与报表处理组件集合(三)

    在前2篇文章这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧 和这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑)中,大伙热情高涨.再次拿出自己的私货,在.NET平台 ...

随机推荐

  1. css制作旋转风车(transform 篇)

    做这个案例之前首先要大概了解CSS的transform的属性 transform 属性向元素应用 2D 或 3D 转换.该属性允许我们对元素进行旋转.缩放.移动或倾斜. 看看效果图 打开的时候自动旋转 ...

  2. HTML5表格(table)篇

    初学HTML接触table少不了,但是实际应用的地方也有. 简单说明HTML <table> 标签 定义和用法 <table> 标签定义 HTML 表格. 简单的 HTML 表 ...

  3. luoguP1134 阶乘问题 [数论]

    题目描述 也许你早就知道阶乘的含义,N阶乘是由1到N相乘而产生,如: 12! = 1 x 2 x 3 x 4 x 5 x 6 x 7 x 8 x 9 x 10 x 11 x 12 = 479,001, ...

  4. kafka拦截器原理|案例实操

    拦截器原理 Producer拦截器(interceptor)是在Kafka 0.10版本被引入的,主要用于实现clients端的定制化控制逻辑. 对于producer而言,interceptor使得用 ...

  5. NXOpenC#_Training_cam(cn)【转载】

  6. inobounce.js : 禁止IOS H5的滑动回弹

    IOS的移动端/H5/webapp 页面如果滚动到底部或者在页面顶部再往上拉,都会出现一个回弹的效果. 想取消这个效果可以引入一个简单的库就行,不用再写繁琐的样式. github地址 直接引入就行 & ...

  7. js的线程和同步异步以及console.log机制

    项目上线了,闲下来就写写东西吧.积累了好多东西都没有做笔记~挑几个印象深刻的记录一下吧. js的同步异步以及单线程问题: 都知道单线程是js的一大特性.但是通常io(ajax获取服务器数据).用户/浏 ...

  8. Hadoop节点集群挂了,Hbase数据源损坏怎么办

    今天集群节点一下子挂了5台,hbase的数据块也损坏. hadoop日志 .0.15:36642 dest: /ip:50010 2014-08-26 15:01:14,918 WARN org.ap ...

  9. Python+Django+ansible playbook自动化运维项目实战✍✍✍

    Python+Django+ansible playbook自动化运维项目实战  整个课程都看完了,这个课程的分享可以往下看,下面有链接,之前做java开发也做了一些年头,也分享下自己看这个视频的感受 ...

  10. 24-Ubuntu-文件和目录命令-查找文件内容-grep

    grep Linux系统中grep命令是一种强大的文本搜索工具. grep允许文本文件进行模式查找,所谓模式查找,又被称为正则表达式. 选项 含义 -n 显示匹配行及行号 -v 显示不包括匹配文本的所 ...