map集合
/* java.util.Map接口中常用的方法 1、Map和Collection 没有继承关系 2、Map集合以key和value的方式存储数据:键值对 key和valuea都是引用数据类型 key和value都是存储对象的内存地址 key起到主导地位,value是key的一个附属品 3、Map接口中常用的方法: Set(K) keySet()获取Map集合中所有的key(所有的键是一个set集合) V remove(Object key) 通过key删除键值对 int size()获取Map集合中键值对的个数 Collection<V> values() 获取Map集合中所有的value,返回一个Collection set<Map.Entry<K,V>> entrySet() 将Map集合转化为set集合 假设现在有一个Map集合 map集合对象 key value -------------- 1 zhangsan【Map 集合通过entrySet()方法转换成set集合,set集合中的元素类型是Map.Entry<K,V>】 Map.Entry 和 String一样,都是一种类型的名字,只不过:Map.Entry是静态内部类 2 lisi 3 wangwu Set set = map.entrySet(); set集合对象 1=zhangsan 2=lisi 3=wangwu */ import java.util.Collection; import java.util.HashMap; import java.util.Map; public class MapTest { public static void main(String[] args) { //创建Map集合对象 Map<Integer,String> map = new HashMap<>(); //向Map集合中添加键值对 map.put(1,"zhangsan");//1 在这里进行了自动装箱 map.put(2,"lisi"); map.put(3,"wangwu"); //通过key获取value String value = map.get(1); System.out.println(value); //获取所有的value Collection<String> values =map.values(); for(String s: values){ System.out.println("所有的value值"+s); } //获取键值对数量 System.out.println("键值对的数量:"+map.size()); //通过key删除 key-value map.remove(2); System.out.println("键值对的数量:"+map.size()); //判断是否包含某个key //contains 底层调用的是equals方法进行比较的,所以自定义的类型需要重写equals方法 重写equals方法比较的是内容 System.out.println(map.containsKey(4));//false //判断是否包含某个value System.out.println(map.containsValue("zhangsan"));//true //清空map map.clear(); System.out.println("键值对的数量:"+map.size());//0 //判断是否为空 System.out.println(map.isEmpty()); } }
遍历Map集合
public class MapTest { public static void main(String[] args) { //创建Map集合对象 Map<Integer,String> map = new HashMap<>(); //向Map集合中添加键值对 map.put(1,"zhangsan");//1 在这里进行了自动装箱 map.put(2,"lisi"); map.put(3,"wangwu"); //第一种方法,获取所有的key,通过遍历key,从而遍历value //遍历key,获取所有的Key,key是一个set集合 Set<Integer> keys = map.keySet(); //遍历key,通过key获取value //迭代器可以 Iterator<Integer> it = keys.iterator(); while(it.hasNext()){ Integer key = it.next(); String value =map.get(key); System.out.println(key+"="+value); } //foreach也可以 for(Integer key:keys){ System.out.println(key+"="+map.get(key)); } //第二种方式Set<Map.Entry<K,V>> entrySet() //这种方法是直接把Map集合转化为Set集合。 //set集合中的元素类型是:Map.Entry Set<Map.Entry<Integer,String>> set = map.entrySet(); //遍历Set集合,每一次取出一个node //迭代器 // Iterator<Map.Entry<Integer,String>> it2 = set.iterator(); // while(it2.hasNext()){ // Map.Entry<Integer,String> node = it2.next(); node是一个静态内部类 实现了Map.Entry(K,V)接口 // Integer key = node.getKey(); // String value = node.getValue(); // System.out.println(key+"="+key); // } //foreach //这种方式效率比较高,因为获取key和value都是直接从node对象中获取的属性值 //这种方式比较适合大数据量 for(Map.Entry<Integer,String> node:set){ System.out.println(node.getKey()+"-->"+node.getValue()); } } }
本文含有隐藏内容,请 开通VIP 后查看