Java笔记(二十三)……Map集合
Map接口
Map<K,V>
该集合存储的是键值对,成对往集合里存,而且要保证键的唯一性
常用方法
添加
voidputAll(Map<? extends K,? extends V> m)
删除
voidclear()
判断
booleanisEmpty()
booleancontainsKey(Object key)
booleancontainsValue(Object value)
获取
intsize()
Map集合的两种取出方式
第一种:Set<K> keySet
将Map中的所有键存入到Set集合中。
因为Set具备迭代器,可以迭代方式遍历所有的键
再通过Map的get方法获取对应的value
第二种:Set<Map.Entry<K,V>> entrySet()
将Map集合中的映射关系存放到Set集合中
而这个映射关系我们称之为Map.Entry
Entry其实就是Map中的一个静态内部接口
1: public static void main(String[] args)
2: {
3: //创建一个HashMap集合
4: Map<String,String> m = new HashMap<String,String>();
5:
6: //存入一些键值对
7: m.put("1","A");
8: m.put("2","B");
9: m.put("3","C");
10:
11: //获取存放键值对的Set集合
12: Set<Map.Entry<String,String>> se = m.entrySet();
13:
14: //获取Set集合的迭代器
15: Iterator<Map.Entry<String,String>> ie = se.iterator();
16:
17: //遍历读取集合中的键值对,并打印
18: while(ie.hasNext())
19: {
20: Map.Entry<String,String> me = ie.next();
21: System.out.println("num = "+me.getKey()+"; name = "+me.getValue());
22: }
23: }
Map子类
HashTable
底层的数据结构是哈希表
不可以存入null键null值,线程同步,效率低,后期被HashMap取代
HashMap
底层的数据结构是哈希表
允许存入null键null值,线程不同步
TreeMap
底层的数据结构是二叉树
线程不同步,可以用于给map集合中的键进行排序(通过比较器或者自然排序)
Set集合底层应用的就是TreeMap集合
Map扩展知识
Map集合都是被使用到映射关系上
所以,存在一对多的映射关系,如下:
Map<String,Map<String,String>>
Map<String,List<Student>>
Map应用
字符串统计字数
1: /*
2:
3: "abcabcdea"
4: 打印字母出现的次数
5: 例子 a(3) b(2)
6: */
7: import java.util.*;
8: class MapTest
9: {
10: public static void main(String[] args)
11: {
12: //测试字符串
13: String s = "abcabc123dea";
14:
15: //创建Map对象存放对应字母
16: Map<Character,Integer> map = new TreeMap<Character,Integer>();
17:
18: //循环遍历字符串
19: for(int i = 0 ; i < s.length() ; i ++)
20: {
21: //建立char的对象封装字母
22: Character c = new Character(s.charAt(i));
23:
24: //如果包含该字母,对应value+1,否则存入该新的键值对,value为1,代表次数为1
25: if(map.containsKey(c))
26: {
27: map.put(c,map.get(c)+1);
28: }
29: else
30: map.put(c,1);
31: }
32:
33: //取出对应关系,并打印
34: Set<Map.Entry<Character,Integer>> entrySet = map.entrySet();
35:
36: Iterator<Map.Entry<Character,Integer>> it = entrySet.iterator();
37:
38: while(it.hasNext())
39: {
40: Map.Entry<Character,Integer> entry = it.next();
41: Character c = entry.getKey();
42: Integer i = entry.getValue();
43: System.out.println(c+"("+i+")");
44: }
45: }
46: }
Java笔记(二十三)……Map集合的更多相关文章
- Java笔记(二十四)……集合工具类Collections&Arrays
Collections 集合框架的工具类,方法全部为静态 Collections与Collection的区别 Collection是集合框架的一个顶层接口,里面定义了单列集合的共性方法 Collect ...
- python3.4学习笔记(二十三) Python调用淘宝IP库获取IP归属地返回省市运营商实例代码
python3.4学习笔记(二十三) Python调用淘宝IP库获取IP归属地返回省市运营商实例代码 淘宝IP地址库 http://ip.taobao.com/目前提供的服务包括:1. 根据用户提供的 ...
- Java基础(二十三)集合(6)Map集合
Map接口作为Java集合框架中的第二类接口,其子接口为SortedMap接口,SortedMap接口的子接口为NavigableMap接口. 实现了Map接口具体类有:HashMap(子类Linke ...
- Android(java)学习笔记105:Map集合的遍历之键值对对象找键和值
package cn.itcast_01; import java.util.HashMap; import java.util.Map; import java.util.Set; /* * Map ...
- Android(java)学习笔记104:Map集合的遍历之键找值
package cn.itcast_01; import java.util.HashMap; import java.util.Map; import java.util.Set; /* * Map ...
- Android(java)学习笔记103:Map集合的获取功能
package cn.itcast_01; import java.util.Collection; import java.util.HashMap; import java.util.Map; i ...
- Android(java)学习笔记102:Map集合功能概述
下面通过代码引入Map集合:如下 package cn.itcast_01; import java.util.HashMap; import java.util.Map; /* * 作为学生来说,是 ...
- Java基础知识强化之集合框架笔记57:Map集合之HashMap集合(HashMap<Student,String>)的案例
1. HashMap集合(HashMap<Student,String>)的案例 HashMap<Student,String>键:Student 要求:如果两个对象 ...
- Java基础知识强化之集合框架笔记56:Map集合之HashMap集合(HashMap<String,Student>)的案例
1. HashMap集合(HashMap<String,Student>)的案例 HashMap是最常用的Map集合,它的键值对在存储时要根据键的哈希码来确定值放在哪里. HashMap的 ...
随机推荐
- 深入浅出分析C#接口的作用
1.C#接口的作用 :C#接口是一个让很多初学C#者容易迷糊的东西,用起来好像很简单,定义接口,里面包含方法,但没有方法具体实现的代码,然后在继承该接口的类里面要实现接口的所有方法的代码,但没有真正认 ...
- c#中virtual, abstract和override的区别和用法
virtual是把一个方法声明为虚方法,使派生类可重写此方法,一般建立的方法是不能够重写的,譬如类A中有个方法protected void method(){ 原代码....;}类B继承自类A,类B能 ...
- CF 217 B. Berland Bingo
http://codeforces.com/contest/370/problem/B 题意 :呃,这个题我说不清楚....就是有n个人,第 i 个人手里有 mi 张牌,如果,现在主人念数,念到哪张牌 ...
- POJ 1404 I-Keyboard (DP)
http://poj.org/problem?id=1404 题意 :手机上的要发短信的话,“我”字需要先按一下9键,再按3下6键,所以,现在想要重新布局每个键上的字母数,让最后的那个值最小,也就是说 ...
- HDU 5008 Boring String Problem
题意:给定一个串长度<=1e5,将其所有的不同的字串按照字典序排序,然后q个询问,每次询问字典序第k小的的起始坐标,并且起始坐标尽量小. 分析: 一开始看错题意,没有意识到是求不同的字串中第k小 ...
- 两个表,一个表中的两列关联另一个表的id,如何将这个表中的两列显示为另一个表id对应的内容
表A name user owner machine1 1 2 machine2 3 4 表B userid username 1 aaa 2 bbb 3 ccc 4 ddd 以上两个表,表A 设备的 ...
- MMU、Icache、Dcache
http://blog.csdn.net/iodoo/article/details/8954014 i-cache(instruction cache)是指令高速缓冲存储器. Cache存储体:存放 ...
- SPRING IN ACTION 第4版笔记-第三章ADVANCING WIRING-006-给bean运行时注入值(Environment,Property文件)
一. 直观的给bean注入值如下: @Bean public CompactDisc sgtPeppers() { return new BlankDisc( "Sgt. Pepper's ...
- TYPE C PD测试板 UFP测试板
- C语言考试解答十题
学院比较奇葩,大一下期让学的VB,这学期就要学C++了,然后在开学的前三个周没有课,就由老师讲三个周的C语言,每天9:30~11:30听课,除去放假和双休日,实际听课时间一共是12天*2小时,下午是1 ...