Map

上一篇讲完 collection接口,这篇我们来学习 map接口map接口 也是一个很重要的容器。
map接口 里面的内容都是 键值对,一个key对应一个value。key不可以重复、value可以重复。Map的key一遍都是String。 让我们看看API对此接口的描述:
在这里插入图片描述

Map 接口提供三种collection 视图,允许以 键集、值集 或 键-值映射关系集 的形式查看某个映射的内容。映射顺序定义为迭代器在映射的 collection 视图上返回其元素的顺序。某些映射实现可明确保证其顺序,如 TreeMap类;另一些映射实现则不保证顺序,如 HashMap 类。
视图是什么??
视图其实就是一个集合,但是是一个不能修改的集合,只能对视图进行查询和遍历操作。

Map接口的方法:

  • void clear()
    从此映射中移除所有映射关系(可选操作)。
  • boolean containsKey(Object key)
    如果此映射包含指定键的映射关系,则返回 true。
  • boolean containsValue(Object value)
    如果此映射将一个或多个键映射到指定值,则返回 true。
  • Set<Map.Entry<K,V>> entrySet()
    返回此映射中包含的映射关系的 Set 视图。
  • boolean equals(Object o)
    比较指定的对象与此映射是否相等。
  • V get(Object key)
    返回指定键所映射的值;如果此映射不包含该键的映射关系,则返回 null。
  • int hashCode()
    返回此映射的哈希码值。
  • boolean isEmpty()
    如果此映射未包含键-值映射关系,则返回 true。
  • Set keySet()
    返回此映射中包含的键的 Set 视图。
  • V put(K key, V value)
    将指定的值与此映射中的指定键关联(可选操作)。
  • void putAll(Map<? extends K,? extends V> m)
    从指定映射中将所有映射关系复制到此映射中(可选操作)。
  • V remove(Object key)
    如果存在一个键的映射关系,则将其从此映射中移除(可选操作)。
  • int size()
    返回此映射中的键-值映射关系数。
  • Collection values()
    返回此映射中包含的值的 Collection 视图。

Map的遍历:

  • 使用 keySet
Set<String> set=map.keySet();
for(String key:set){
	System.out.println(key+":"+map.get(key));
}
  • 使用 collection
Collection<String> collection=map.values();
for(String str:collection){
	System.out.println(str);
}
  • 使用 Map.Entry(Map.Entry接口,也就是一直所说的键值对,这个接口是Map中元素需要实现的接口。)
Set<String> set=map.keySet();
for(Entry<String,String> entry:map.entrySet()){
	System.out.println(entry.getKey()+":"+entry.getValue());
}

来看个例子:

import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;

public class Bianli
{
    public static void main(String[] args)
    {
        Map<String, String> map=new HashMap<>();
        map.put("aa", "Animal");
        map.put("bb", "Dog");
        map.put("cc", "Cat");
		map.put("cc", "Cat");//重复元素
		
        // 使用 keySet遍历
        Set<String> set=map.keySet();
        for(String key : set)
        {
            System.out.println(key + ":" + map.get(key));
        }

        // 使用 collection 遍历
        Collection<String> collection=map.values();
        for(String str : collection)
        {
            System.out.println(str);
        }

        // 使用 Map.Entry遍历
        for(Entry<String, String> entry : map.entrySet())
        {
            System.out.println(entry.getKey() + ":" + entry.getValue());
        }
    }

}

执行结果:
在这里插入图片描述

TreeMap

TreeMap相对于Hash Map来说,增加了排序功能。
TreeMap的key是通过Comparable接口 过滤重复 排序,也可以通过Comparator接口的实现类的对象来过滤重复排序

import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
import java.util.TreeMap;

public class Bianli
{
    public static void main(String[] args)
    {
        Map<String, String> map=new TreeMap<>();
        map.put("aa", "Animal");
        map.put("cc", "Cat");
        map.put("bb", "Dog");
        map.put("cc", "Cat");

        Set<String> set=map.keySet();
        for(Entry<String, String> entry : map.entrySet())
        {
            System.out.println(entry);
        }
    }
}

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值