Map集合入门

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

注意事项:当键盘输入字符串的时候比较的的地址值

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值