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) -- 数组 而数组的长度固定, ...
随机推荐
- mysql的sql语句优化方法面试题总结
mysql的sql语句优化方法面试题总结 不要写一些没有意义的查询,如需要生成一个空表结构: select col1,col2 into #t from t where 1=0 这类代码不会返回任何结 ...
- 前端开发HTML&css入门——常用的标签以及一个小练习
meta标签 <!doctype html> <html> <head> <meta charset="utf-8" /> < ...
- Vue/React如何优雅的一劳永逸的注册路由及组件
原文链接: 本人掘金文章 假如图片看不清晰可前往掘金原文预览 官方文档: 组建注册 路由注册 未优化版: 在Vue官方文档 中,我们通过 Vue.component('MyComponentNam ...
- Azkaban和Oozie的区别
Azkaban和Oozie的区别: 当前,实际生产中最流行的两种Hadoop工作流引擎是Azkaban与Oozie.但活跃度最高的当是Azkaban了,下面对两者的异同之处作如下对比. 功能对比 Az ...
- ln创建软链接方式
ln -s 目标文件 软链接
- 升级docker至最新版本
升级docker至最新版本 1.查找主机上关于Docker的软件包 [root@pre1 ~]# rpm -qa | grep docker docker-1.13.1-88.git07f3374.e ...
- Manjaro美化 配置教程
Manjaro Linux的美化 切换源 sudo vi /etc/pacman.conf 加入arch源 [archlinuxcn] SigLevel = Optional TrustedOnly ...
- tf.nn.top_k
评估操作对于测量神经网络的性能是有用的. 由于它们是不可微分的,所以它们通常只是被用在评估阶段 tf.nn.top_k(input, k, name=None) 这个函数的作用是返回 input 中每 ...
- bzoj5118 Fib数列2 二次剩余+矩阵快速幂
题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=5118 题解 这个题一看就是不可做的样子. 求斐波那契数列的第 \(n\) 项,\(n \leq ...
- [洛谷P2459] SDOI2011 消耗战
问题描述 在一场战争中,战场由n个岛屿和n-1个桥梁组成,保证每两个岛屿间有且仅有一条路径可达.现在,我军已经侦查到敌军的总部在编号为1的岛屿,而且他们已经没有足够多的能源维系战斗,我军胜利在望.已知 ...