JavaSE Map的使用
1.Map概述
Map与Collection并列存在。用来保存具有映射关系的数据:Key-Value
LinkedHashMap用一个链表维护加入进Map的顺序,遍历得到的顺序和加入顺序一致。
2.Map中的主要方法
package org.tizen.test; import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set; import org.junit.Test; /*
*
Object put(Object key,Object value) 向Map中加入一个key以及value
Object remove(Object key) 删除制定的 key以及相应的value,即删除制定的key-value对
void putAll(Map t)
void clear()
Object get(Object key) 获取制定的key的value值,如无。返回null
boolean containsKey(Object key)
boolean containsValue(Object value)
int size()
boolean isEmpty()
boolean equals(Object obj) */
public class TestMain { @Test
public void TestMapAPI()
{
//遍历得到的顺序和加入顺序不一致
Map map = new HashMap<>();
map.put("image", "/opt/image.jpg");
map.put("title", "setting");
map.put("size", 80);
m.put("image", "/opt/image1.jpg");//覆盖之前的map.put("image", "/opt/image.jpg");
System.out.println(map.size());//3
System.out.println(map.get("image"));
System.out.println(map.get("title"));
System.out.println(map.get("size"));
boolean b = map.containsValue("setting");
System.out.println(b);//true
}
}
@Test
/*
* * 元视图操作的方法:Set keySet() Collection values() Set entrySet()
*/
public void Test2() {
Map m = new HashMap();
m.put("123a", 97);
m.put("b", 98);
m.put("AbC", 1221);
m.put(null, 1);
// 1.得到Map的KeySet,遍历
Set s = m.keySet();
System.out.println("遍历set");
for (Object o : s) {
System.out.println(o);
} // 2.遍历values
Collection c = m.values();
System.out.println("增强for循环遍历values");
for (Object o : c) {
System.out.println(o);
}
System.out.println("迭代器遍历values");
Iterator i = c.iterator();
while (i.hasNext()) {
System.out.println(i.next());
}
// 3.遍历key-value对 by 增强for循环遍历
Set entry1 = m.entrySet(); for (Object o : entry1) {
// need cast
Map.Entry me = (Map.Entry) o;
System.out.println(me.getKey() + ":" + me.getValue());
}
// 4.遍历key-value对 by iterator
Set entrySet = m.entrySet();
Iterator iterator = entrySet.iterator();
while (iterator.hasNext()) {
Map.Entry entry2 = (Map.Entry) iterator.next();
System.out.println(entry2.getKey() + ":" + entry2.getValue());
} }
@Test
// 自然排序
public void test3() {
Map map = new LinkedHashMap();
map.put("AA", 213);
map.put("BB", 45);
map.put(123, "CC");
map.put(null, null);
map.put("AABB", 89);
Set set1 = map.keySet();
for (Object obj : set1) {
System.out.println(obj + ":" + map.get(obj));
}
}
@Test
public void test4() {
Map map = new LinkedHashMap();
map.put("AA", 213);
map.put("BB", 45);
map.put(123, "CC");
map.put(null, null); Set<Map.Entry> set = map.entrySet();
Iterator it = set.iterator();
while (it.hasNext()) {
Map.Entry m = (Map.Entry) it.next();
System.out.println(m.getKey() + " = " + m.getValue());
}
}
JavaSE Map的使用的更多相关文章
- JavaSE Map集合
Map集合 在Map集合中保存的数据为一组数据,其中:一个数据为key,另外一个数据为value.而key和value具备对应的关系,在集合中它们属于一组(一对)数据.而每个key只能对应唯一的一个v ...
- Map-API及详解
常用API 类别 方法 增加 put.putAll 删除 remove.removeAll.clear 查询 get 取值 entrySet.keySet.values 长度 size 判断 cont ...
- mybatis中的动态SQL语句
有时候,静态的SQL语句并不能满足应用程序的需求.我们可以根据一些条件,来动态地构建 SQL语句. 例如,在Web应用程序中,有可能有一些搜索界面,需要输入一个或多个选项,然后根据这些已选择的条件去执 ...
- JavaSE中Map框架学习笔记
前言:最近几天都在生病,退烧之后身体虚弱.头疼.在床上躺了几天,什么事情都干不了.接下来这段时间,要好好加快进度才好. 前面用了三篇文章的篇幅学习了Collection框架的相关内容,而Map框架相对 ...
- JavaSE集合(十)之Map
前面给大家介绍了集合家族中的Collection家族,这一篇给大家分享的是集合中的另一个家族就是Map家族.以前的时候学习Map的时候没有很认真的去学习,我觉得很多东西还是不是很清楚. 这次我将总结的 ...
- JavaSE集合(八)之Map
前面给大家介绍了集合家族中的Collection家族,这一篇给大家分享的是集合中的另一个家族就是Map家族.以前的时候学习Map的时候没有很认真的去学习,我觉得很多东西还是不是很清楚. 这次我将总结的 ...
- javaSE学习笔记(11)--- Map
javaSE学习笔记(11)--- Map 1.Map集合 现实生活中,我们常会看到这样的一种集合:IP地址与主机名,身份证号与个人,系统用户名与系统用户对象等,这种一一对应的关系,就叫做映射.Jav ...
- [010] - JavaSE面试题(十):集合之Map
第一期:Java面试 - 100题,梳理各大网站优秀面试题.大家可以跟着我一起来刷刷Java理论知识 [010] - JavaSE面试题(十):集合之Map 第1问:HashMap和HashTable ...
- JavaSE(十)之Map总结
上一篇是总结了Collection接口的各种实现类,这一篇我将分享的是Map的总结,希望大家点评! 一.Map接口 1.1.为什么Collection不能满足集合的所有功能? Collection接口 ...
随机推荐
- JS 绘制心形线
JS 绘制心形线 <!DOCTYPE HTML> <html> <head> <meta charset="utf-8"> < ...
- Configure Red Hat Enterprise Linux shared disk cluster for SQL Server
下面一步一步介绍一下如何在Red Hat Enterprise Linux系统上为SQL Server配置共享磁盘集群(Shared Disk Cluster)及其相关使用(仅供测试学习之用,基础篇) ...
- 在 Yii2 项目中使用 Composer 添加 FontAwesome 字体资源
2014-06-21 19:05 原文 简体 繁體 2,123 次围观 前天帮同事改个十年前的网站 bug,页面上一堆 include require 不禁让人抱头痛哭.看到 V2EX 上的讨论说,写 ...
- A. Nearest Common Ancestors
A. Nearest Common Ancestors Time Limit: 1000ms Case Time Limit: 1000ms Memory Limit: 10000KB 64-bi ...
- Axure:从简单搜索到联想搜索的部件制作
导读:最近一直都在整理原型部件,要说准备的最有感触的,当属搜索框无疑.搜索框的整理,前后加起来共耗时两天多.从最开始的按钮和文本框,到后来的图示,提示和联想查询.耗费了不少的心血,有必要总结一下,留个 ...
- 【Luogu】P3758可乐(矩阵优化DP)
题目链接 一开始想到这可能能用矩阵优化,但以为暴力就能卡过……T成二十分 首先我们回顾一下我们的暴力转移方程 用f[i][j][0/1]表示在i时刻,j点,1不爆炸,0已爆炸的方案数,那么f[i][j ...
- VBA Split()函数
Split()函数返回一个数组,其中包含基于分隔符分割的特定数量的值. 语法 Split(expression[,delimiter[,count[,compare]]]) 参数说明 Expressi ...
- KD-Tree 的笔记
声明: 蒟蒻对于 KD-Tree 的一点理解,写在博客里面作为笔记. 1.KD-Tree 的定义 1)关于 K-D KD-Tree 中的 D 即为 Dimension ,意思也就是维度. 所以 KD- ...
- P1857 质数取石子 (DP,递推)
题目描述 桌上有若干个石子,每次可以取质数个.谁先取不了,谁就输.问最少几步能赢?(一个人取一次算一步) 输入输出格式 输入格式: 第一行N,表示有N组数据 接下来N行为石子数 输出格式: 每组数据一 ...
- oracle 当中,(+)是什么意思
SELECT A.id, B.IDDFROM A, BWHERE A.id(+)=B.IDD等价于SELECT A.id, B.IDDFROM A RIGHT OUTER JOIN B ON ( A. ...