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接口 ...
随机推荐
- clipboard 在 vue 中的使用
简介 页面中用 clipboard 可以进行复制粘贴,clipboard能将内容直接写入剪切板 安装 npm install --save clipboard 使用方法一 <template&g ...
- luogu2569 [SCOI2010]股票交易
题解看这里 #include <iostream> #include <cstring> #include <cstdio> using namespace std ...
- ffmpeg常见名词解析
scan_all_pmts, 扫描全部的ts流的"Program Map Table"表.
- 九度oj 题目1096:日期差值
题目描述: 有两个日期,求两个日期之间的天数,如果两个日期是连续的我们规定他们之间的天数为两天 输入: 有多组数据,每组数据有两行,分别表示两个日期,形式为YYYYMMDD 输出: 每组数据输出一行, ...
- 每天一个linux命令目录(转)
一. 文件目录操作命令: 1.每天一个linux命令(1):ls命令 2.每天一个linux命令(2):cd命令 3.每天一个linux命令(3):pwd命令 4.每天一个linux命令(4):mk ...
- 【bzoj1444】[Jsoi2009]有趣的游戏 AC自动机+矩阵乘法
题目描述 输入 注意 是0<=P 输出 样例输入 样例输出 题解 AC自动机+矩阵乘法 先将所有字符串放到AC自动机中,求出Trie图. 然后构建邻接矩阵:如果x不是某个字符串的末位置,则x连向 ...
- 【Luogu】P1383高级打字机
可持久化线段树模板题之一. 权当温习主席树模板 #include<cstdio> #include<cstdlib> #include<cctype> #defin ...
- BZOJ 4259 残缺的字符串 ——FFT
[题目分析] 同bzoj4503. 只是精度比较卡,需要试一试才能行O(∩_∩)O 用过long double,也加过0.4.最后发现判断的时候改成0.4就可以了 [代码] #include < ...
- python 写excal
workbook.save(filename)
- 查看mysql库中所有表的大小和记录数
查看mysql库中所有表的大小和记录数 ,), 'MB') as total_size FROM information_schema.TABLES WHERE TABLE_SCHEMA='datab ...