HashMap -双列集合的遍历与常用的方法
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 -双列集合的遍历与常用的方法的更多相关文章
- JAVA双列集合HashMap
HashMap 双列集合HashMap是属于java集合框架3大类接口的Map类, Map接口储存一组成对的键-值对象,提供key(键)到value(值)的映射.Map中的key不要求有序,不允许 ...
- (10)集合之双列集合Map,HashMap,TreeMap
Map中的元素是两个对象,一个对象作为键,一个对象作为值.键不可以重复,但是值可以重复. 看顶层共性方法找子类特有对象. Map与Collection在集合框架中属并列存在 Map存储的是键值对 Ma ...
- 双列集合Map的嵌套遍历
双列集合Map的嵌套使用,例如HashMap中还有一个HashMap,这样的集合遍历起来稍微有点儿复杂.例如一个集合:HashMap<Integer,HashMap<String,Inte ...
- Map集合(双列集合)
Map集合(双列集合)Map集合是键值对集合. 它的元素是由两个值组成的,元素的格式是:key=value. Map集合形式:{key1=value1 , key2=value2 , key3=val ...
- Java之Map接口(双列集合)
Map集合概述 现实生活中,我们常会看到这样的一种集合:IP地址与主机名,身份证号与个人,系统用户名与系统用户对象等,这种一一对应的关系,就叫做映射.Java提供了专门的集合类用来存放这种对象关系的对 ...
- Java中的集合(七)双列集合顶层接口------Map接口架构
Java中的集合(七)双列集合顶层接口------Map接口 一.Map接口的简介 通过List接口,我们知道List接口下的集合是单列集合,数据存储是单列的结构.Map接口下是一个键值对(key-v ...
- 双列集合Map
1.双列集合Map,就是存储key-value的键值对. 2.hashMap中键必须唯一,值可以不唯一. 3.主要方法:put添加数据 getKey---通过key获取数据 keySet- ...
- Map集合——双列集合
双列集合<k, v> Map: Map 和 HashMap是无序的: LinkedHashMap是有序的: HashMap & LinkedHashMap: put方法: 其中,可 ...
- java oop 单列 双列 集合, 迭代器 的使用和说明
一.集合(Collection) (1)集合的由来? 我们学习的是Java -- 面向对象 -- 操作很多对象 -- 存储 -- 容器(数组和StringBuffer) -- 数组 而数组的长度固定, ...
随机推荐
- 最全的 Java 知识总结- Github 日增 10 star
项目地址: 如果觉得有帮助,希望大家给个 star 鼓励以下:同时也希望大家多多 fork,一起加入进来. 为什么选择做这个开源项目 首先,希望提高自己:因为选择做这个,自己肯定就会花时间去提高自己的 ...
- java SSM框架 代码生成器 快速开发平台 websocket即时通讯 shiro redis
A代码编辑器,在线模版编辑,仿开发工具编辑器,pdf在线预览,文件转换编码 B 集成代码生成器 [正反双向](单表.主表.明细表.树形表,快速开发利器)+快速表单构建器 freemaker模版技术 , ...
- Webstorm上已有的本地项目上传到Github
1.Webstorm左上角File —— Settings—— Github, Auth Type改成password,在Login和Password中输入自己的github账户和密码,点Test测试 ...
- 通过利用immutability的能力编写更安全和更整洁的代码
通过利用immutability的能力编写更安全和更整洁的代码 原文:Write safer and cleaner code by leveraging the power of "Imm ...
- JavaScript——call() 方法
function Product(name, price) { this.name = name; this.price = price; } function Food(name, price) { ...
- Linux安装Sqoop及基础使用
下载Sqoop 官网地址 http://sqoop.apache.org/ wget http://mirrors.hust.edu.cn/apache/sqoop/1.4.7/sqoop-1.4.7 ...
- CentOS 7系统安装nginx+php
安装介绍1.系统环境CentOS7 2.nginx版本1.12 3.PHP版本7.2 下载地址 4.MySQL版本5.7 安装nginx添加centos7的 nginx yum源 然后执行安装 sud ...
- ForkJoinPool详解
本文的主要目的是介绍 ForkJoinPool 的适用场景,实现原理,以及示例代码. 说在前面可以说是说明,也可以说下面是结论: ForkJoinPool 不是为了替代 ExecutorService ...
- 线程工具类 - Semaphore(信号量)
Semaphore官方文档 一.使用信号量实现线程间的通信 /** * Demo:使用信号量实现线程间通信*/ public class SemaphoreDemo { public static v ...
- man LVCREATE
LVCREATE(8) LVCREATE(8) NAME/名称 lvcreat ...