Map集合入门
1、Map集合作用
处理一一对应的关系集合
Collection 是单列集合(单身汉)
Map 是双列集合(夫妻对)**
2、Map集合常用方法
A.增和改
public V put(K key,V value) //把指定的键和值添加到Map集合当中
B.删
public V remove(K key) //把指定的键key 对应关系的值删除,并且返回删除的值
C.查
public int size() //返回map集合的大小数据
public V get(K key) //根据指定的键key 获取对应的值
public boolean containsKey(K) //是否包含指定的键key 包含返回true
public boolean containsValue(V) //是否包含指定的值value 包含返回true
D.遍历
public Set<K> keySet() //获取Map集合当中所有的键,存储在Set集合中
public Set<Map.Entry<K,V>> entrySet() //获取到Map集合当中所有的键值对对象的集合
3、Map集合的遍历方式
A.通过键,找到值
Set<String> set = map.keySet();
for (String s : set) {
System.out.println(s);
}
B.Entry键值对对象
Set<Map.Entry<String, String>> entry = map.entrySet();
//增强for循环
for (Map.Entry<String, String> en : entry) {
System.out.println(en.getKey() + "-->" + en.getValue());
4、Map集合的遍历方式
HashTable(java.utli.HashTable):
1.不能存null键和值
2.单线程,线程安全,速度慢
3.底层哈希表
4.被HasMap.Arraylist取代
5.子类Properties(IO流)
HashMap
1.底层哈希表
2.线程不安全.多线程,速度快
3.可存null、
5、统计字符串出现次数案例
(思路)
计算一个字符串中每-个字符出现次数。
1. 获取一个字符串对象
2. 创建一个Map集合,键代表字符,值代表次数。
3. 遍历字符串得到每个字符。
4. 判断Map中是否有该键。
5. 如果没有,第一次出现,存储次数为1;如果有,则说明已经出现过,获取到对应的值进行++,再次存储。
6. 打印最终结果
import java.util.Map;
import java.util.Scanner;
//统计字符串出现次数
public class Test02ScannerCase {
public static void main(String[] args) {
//计算一个字符串中字符出现的次数
//1.从键盘输入字符串
System.out.println("请输入:");
String st = new Scanner(System.in).next();
//2.把字符串转换为字符数组来遍历
char[] ca = st.toCharArray();
//3.定义一个Map集合
Map<Character, Integer> map = new HashMap<>();
//4.用增强for循环判断每一个字符出现的个数
for (char c : ca) {
if (map.containsKey(c)) {
//如果key有c,获取value值再把value的值加1保证value的值计数
Integer value = map.get(c);
value++;
//添加到map集合
map.put(c, value);
} else {
//map集合中没有该字符给value赋初值
map.put(c, 1);
}
}
//5.遍历map集合
for (Character c : map.keySet()) {
Integer value = map.get(c);
System.out.println(c+"="+value);
}
}
}
运行结果:
请输入:aAaaBc66
a=3
A=1
B=1
c=1
6=2
注意事项:当键盘输入字符串的时候比较的的地址值