package cn.learn.Map;
/*
java.util.Hashtable<k,y> implements Map<k,v>
早期双列集合,jdk1.0开始
同步的,单线程,安全,慢,底层也是哈希表
与HashMap不一样的是,Hashtable key,value不允许存储null Hashtable与vector一样被多线程集合HashMap和ArrayList取代 但是Hashtable的子类Properties依然活跃,它是唯一一个与I/O流相结合的集合 */
public class HashtableClass {
}
 package cn.learn.Map;

 import java.util.HashMap;
import java.util.LinkedHashMap; /*
java.util.LinkedHashMap<k,v> extends HashMap
底层原理:
哈希表+链表(记录元素的顺序)
*/
public class LinkedHashMapClass {
public static void main(String[] args) {
HashMap<String,String> map= new HashMap<>();
map.put("a","b");
map.put("3a","b");
map.put("2a","b");
map.put("1a","b");
System.out.println(map); //key不重复且无序 LinkedHashMap<String,String> linked = new LinkedHashMap<>();
linked.put("a","b");
linked.put("3a","b");
linked.put("2a","b");
linked.put("1a","b");
System.out.println(linked); //有序且不重复,存取一致
} }
 package cn.learn.Map;

 import java.security.Key;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set; /*
java.util.Map1<k,v> -双列集合
一个元素包含两个值(一个key,一个value),key不能重合
Map中key和value的数据类型可以相同,也可以不同 java.util.HashMap<k,v>集合 implements Mqp<k,v>接口
HashMap集合的特点
1.HashMap集合底层是哈希表:查询的速度特别的快
2.存储的元素和取出元素的顺序可能不一致
3.底层是:数组+单向链表/红黑树 = 哈希表 java.util.LinkedHashMap<k,v> extends HashMap<k,v>
LinkedHashMap的特点:
1.存取元素的顺序一致
2.哈希表+链表(保证迭代顺序) HashMap存储自定义类型键值
Map为了保证唯一性,需要重写hashCode和equals方法,以保证key唯一
和HashSet一样,value可不唯一 */
public class MapMethods {
public static void main(String[] args) {
show1();
}
private static void show1(){
HashMap<String,String> hashMap = new HashMap<>();
//put添加集合元素,若key不在,返回value为空,若存在替换value,返回被替换的value
System.out.println(hashMap.put("1","da")); //返回null System.out.println(hashMap.put("1","da2")); //返回被替换的值da System.out.println(hashMap); //打印了不是地址,说明重写了toString方法{1=da2} //remove(Object key)删除元素,存在返回删除的value,不存在返回null
String remove = hashMap.remove("1");
System.out.println(remove); //da2 //get(Object key)获取value
//containsKey(Object key)判断是否包含指定的键
// 包含返回true不包含返回false,和遍历一起使用进行筛选 //遍历双列集合
System.out.println(hashMap.put("2","da29"));
System.out.println(hashMap.put("5","da42"));
System.out.println(hashMap.put("26","5da2")); //KeySet()实际是把Key值取出放入Set<key>集合(不允许重复),则可用迭代器,增强for
Iterator<String> iter=hashMap.keySet().iterator(); //此时Set放入的是key值,迭代的也是key值
while(iter.hasNext()){
String k= iter.next();
System.out.println(hashMap.get(k));
}
//增强for遍历
for (String str : hashMap.keySet()) {
System.out.println(hashMap.get(str));
} /*
entrySet遍历
在Map集合中有个内部接口Entry,Map.Entry<k,v>
作用:当Map集合一创建,就会有个Entry对象(键与值的映射关系),放入Set中
返回类型 Set<Map.Entry<K,V>>,再调用Set的iterator方法,使用迭代器,取出Map.Entry<Object,Object>
再调用Entry的两个方法遍历
Map.Entry有两个方法,getKey和getValue
*/
//放入Set
Set<Map.Entry<String,String>> set = hashMap.entrySet();
//使用迭代器
Iterator<Map.Entry<String,String>> it = set.iterator();
//利用迭代器方法遍历
while(it.hasNext()){
//取得Set的元素
Map.Entry<String,String> entry= it.next();
//调用 Map.Entry的方法
System.out.println(entry.getKey());
System.out.println(entry.getValue());
}//当然可以也可以使用增强for循环 }
}

HashMap -双列集合的遍历与常用的方法的更多相关文章

  1. JAVA双列集合HashMap

    HashMap 双列集合HashMap是属于java集合框架3大类接口的Map类,   Map接口储存一组成对的键-值对象,提供key(键)到value(值)的映射.Map中的key不要求有序,不允许 ...

  2. (10)集合之双列集合Map,HashMap,TreeMap

    Map中的元素是两个对象,一个对象作为键,一个对象作为值.键不可以重复,但是值可以重复. 看顶层共性方法找子类特有对象. Map与Collection在集合框架中属并列存在 Map存储的是键值对 Ma ...

  3. 双列集合Map的嵌套遍历

    双列集合Map的嵌套使用,例如HashMap中还有一个HashMap,这样的集合遍历起来稍微有点儿复杂.例如一个集合:HashMap<Integer,HashMap<String,Inte ...

  4. Map集合(双列集合)

    Map集合(双列集合)Map集合是键值对集合. 它的元素是由两个值组成的,元素的格式是:key=value. Map集合形式:{key1=value1 , key2=value2 , key3=val ...

  5. Java之Map接口(双列集合)

    Map集合概述 现实生活中,我们常会看到这样的一种集合:IP地址与主机名,身份证号与个人,系统用户名与系统用户对象等,这种一一对应的关系,就叫做映射.Java提供了专门的集合类用来存放这种对象关系的对 ...

  6. Java中的集合(七)双列集合顶层接口------Map接口架构

    Java中的集合(七)双列集合顶层接口------Map接口 一.Map接口的简介 通过List接口,我们知道List接口下的集合是单列集合,数据存储是单列的结构.Map接口下是一个键值对(key-v ...

  7. 双列集合Map

    1.双列集合Map,就是存储key-value的键值对. 2.hashMap中键必须唯一,值可以不唯一. 3.主要方法:put添加数据    getKey---通过key获取数据    keySet- ...

  8. Map集合——双列集合

    双列集合<k, v> Map: Map 和 HashMap是无序的: LinkedHashMap是有序的: HashMap & LinkedHashMap: put方法: 其中,可 ...

  9. java oop 单列 双列 集合, 迭代器 的使用和说明

    一.集合(Collection) (1)集合的由来? 我们学习的是Java -- 面向对象 -- 操作很多对象 -- 存储 -- 容器(数组和StringBuffer) -- 数组 而数组的长度固定, ...

随机推荐

  1. MVC 与 MVP 并无两样

    关于 MVC 的定义介绍,摘一段百度百科介绍: MVC 是一种使用 MVC(Model View Controller 模型-视图-控制器)设计创建 Web 应用程序的模式: Model(模型)表示应 ...

  2. 异常处理 VEH

    不算新的东西,也都不小了, VEH的结构处理,平行于SEH,但是略有区别, 相关函数有四个 PVOID WINAPI AddVectoredExceptionHandler( _In_ ULONG F ...

  3. SCRUM REPORT DIRECTORY

    Alpha sprint scrum 1 scrum 2 scrum 3 scrum 4 scrum 5 scrum 6 scrum 7 scrum 8 scrum 9 scrum 10 Beta s ...

  4. PHP实现session共享

    通过修改PHP-FPM配置文件,实现session会话共享: - 配置PHP使用memcached服务器共享Session信息 - 客户端访问两台不同的后端Web服务器时,Session 信息一致 环 ...

  5. layer-框架使用修改部分

    关于框架中js调子方法出错的处理 top.layer.open({ id: options.id, type: 2, shade: options.shade, title: options.titl ...

  6. APP稳定性测试-monkey执行

    Monkey命令行可用的全部选项 *示例 : adb shell monkey -p cn.lejiayuan.alpha --pct-touch 30 --pct-motion 15 --pct-t ...

  7. ClickOnce是什么?如何使用?

    ClickOnce是一种部署方式,主要解决C/S软件版本更新后,所有客户端都要重新安装的问题. 场景:假如,你的客户有1000个,你的服务端更新后,这1000个客户都要重新安装,难道要员工一个一个的电 ...

  8. php strchr()函数 语法

    php strchr()函数 语法 作用:搜索字符串在另一字符串中的第一次出现.直线电机哪家好 语法:strchr(string,search,before_search); 参数: 参数 描述 st ...

  9. 【HDOJ6665】Calabash and Landlord(dfs)

    题意:二维平面上有两个框,问平面被分成了几个部分 x,y<=1e9 思路:分类讨论可以 但数据范围实在太小了,离散化以后随便dfs一下 #include<bits/stdc++.h> ...

  10. 20180711-Java Number类

    下面是一个装箱与拆箱的例子: public class Test{ public static void main(String args[]){ Integer x = 5; // boxes in ...