java集合Map使用以及常见的五种方法

简介:

Map是用于保存具有映射关系的数据集合,它具有双列存储的特点,即一次必须添加两个元素,即一组键值对==><Key,Value>,其中Key的值不可重复(当Key的值重复的时候,后面插入的对象会将之前插入的具有相同的Key值的对象覆盖掉),Value的值可重复。Map作为接口,它最常见的实现类是HashMap和TreeMap,作为接口它抽取了所有实现类的共有方法。同时Map不具有带索引的方法,因此无法使用普通for循环来遍历Map集合

一、概述

将键映射到值的对象
一个映射不能包含重复的键
每个键最多只能映射到一个值
Map接口和Collection接口的不同
Map是双列的,Collection是单列的
Map的键唯一,Collection的子体系Set是唯一的
Map集合的数据结构针对键有效,跟值无关;Collection集合的数据结构是针对元素有效

属性作用
HashMap基于哈希表实现,具有快速的查找和插入操作,适用于需要快速查找键值对的场景。
TreeMap基于红黑树实现,可以对键进行排序,并提供了一系列与排序相关的方法,适用于需要对键进行排序的场景。
LinkedHashMap基于哈希表和链表实现,保持键值对的插入顺序,适用于需要保持插入顺序的场景。

二、Map功能介绍:

a:添加功能
V put(K key,V value):添加元素。这个其实还有另一个功能?替换
如果键是第一次存储,就直接存储元素,返回null
如果键不是第一次存在,就用值把以前的值替换掉,返回以前的值
b:删除功能
void clear():移除所有的键值对元素
V remove(Object key):根据键删除键值对元素,并把值返回
c:判断功能
boolean containsKey(Object key):判断集合是否包含指定的键
boolean containsValue(Object value):判断集合是否包含指定的值
boolean isEmpty():判断集合是否为空
d:获取功能
Set<Map.Entry<K,V>> entrySet(): 返回一个键值对的Set集合
V get(Object key):根据键获取值
Set keySet():获取集合中所有键的集合
Collection values():获取集合中所有值的集合
e:长度功能
int size():返回集合中的键值对的对数

三、map官方总结

Map 接口中键和值一一映射. 可以通过键来获取值。

  • 给定一个键和一个值,你可以将该值存储在一个 Map 对象。之后,你可以通过键来访问对应的值。

  • 当访问的值不存在的时候,方法就会抛出一个 NoSuchElementException 异常。

  • 当对象的类型和 Map 里元素类型不兼容的时候,就会抛出一ClassCastException 异常。

  • 当在不允许使用 Null 对象的 Map 中使用 Null 对象,会抛出一个 NullPointerException 异常。

  • 当尝试修改一个只读的 Map 时,会抛出一个 UnsupportedOperationException 异常。

四、实例

public class CollectionsDemo {
 
   public static void main(String[] args) {
      Map m1 = new HashMap(); 
      m1.put("Zara", "8");
      m1.put("Mahnaz", "31");
      m1.put("Ayan", "12");
      m1.put("Daisy", "14");
      System.out.println();
      System.out.println(" Map Elements");
      System.out.print("\t" + m1);
   }
}

五.Map使用的五种方法:

package nc.util.TestClientTools;
 
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;
/**
 * map集合遍历的五种方法
* @FileName: CircleMap.java 
* @ClassName: nc.util.TestClientTools.CircleMap
* @Description: TODO(这里用一句话描述这个类的作用) 
* @author chenfang 
* @email ichenfang163@163.com 
* @date 2017-12-11 下午3:54:24 
* @version V1.0
*
 */
//循环遍历map的五种方法
public class CircleMap {
	public static void main(String[] args) {
		Map<String, Integer> tempMap = new HashMap<String, Integer>();
		tempMap.put("a", 1);
		tempMap.put("b", 2);
		tempMap.put("c", 3);
		// JDK1.4中
		// 遍历方法一 hashmap entrySet() 遍历
		System.out.println("方法一");
		Iterator it = tempMap.entrySet().iterator();
		while (it.hasNext()) {
			Map.Entry entry = (Map.Entry) it.next();
			Object key = entry.getKey();
			Object value = entry.getValue();
			System.out.println("key=" + key + " value=" + value);
		}
		System.out.println("");
		// JDK1.5中,应用新特性For-Each循环
		// 遍历方法二
		System.out.println("方法二");
		for (Map.Entry<String, Integer> entry : tempMap.entrySet()) {
			String key = entry.getKey().toString();
			String value = entry.getValue().toString();
			System.out.println("key=" + key + " value=" + value);
		}
		System.out.println("");
 
		// 遍历方法三 hashmap keySet() 遍历
		System.out.println("方法三");
		for (Iterator i = tempMap.keySet().iterator(); i.hasNext();) {
			Object obj = i.next();
			System.out.println(obj);// 循环输出key
			System.out.println("key=" + obj + " value=" + tempMap.get(obj));
		}
		for (Iterator i = tempMap.values().iterator(); i.hasNext();) {
			Object obj = i.next();
			System.out.println(obj);// 循环输出value
		}
		System.out.println("");
 
		// 遍历方法四 treemap keySet()遍历
		System.out.println("方法四");
		for (Object o : tempMap.keySet()) {
			System.out.println("key=" + o + " value=" + tempMap.get(o));
		}
		System.out.println("11111");
 
		// java如何遍历Map <String, ArrayList> map = new HashMap <String,
		// ArrayList>();
		System.out.println("java  遍历Map <String, ArrayList> map = new HashMap<String, ArrayList>();");
		Map<String, ArrayList> map = new HashMap<String, ArrayList>();
		Set<String> keys = map.keySet();
		Iterator<String> iterator = keys.iterator();
		while (iterator.hasNext()) {
			String key = iterator.next();
			ArrayList arrayList = map.get(key);
			for (Object o : arrayList) {
				System.out.println(o + "遍历过程");
			}
		}
		System.out.println("2222");
 
		// 遍历方法五
		Map<String, List> mapList = new HashMap<String, List>();
		for (Map.Entry entry : mapList.entrySet()) {
			String key = entry.getKey().toString();
			List<String> values = (List) entry.getValue();
			for (String value : values) {
				System.out.println(key + " --> " + value);
			}
		}
	}
}
  • 12
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值