Java中Map集合中的Entry对象用法

Entry: 键值对 对象。

在Map类设计是,提供了一个嵌套接口(static修饰的接口):Entry。Entry将键值对的对应关系封装成了对象,即键值对对象,这样我们在遍历Map集合时,就可以从每一个键值对(Entry)对象中获取对应的键与对应的值。

Entry为什么是静态的?

Entry是Map接口中提供的一个静态内部嵌套接口,修饰为静态可以通过类名调用。

Map集合遍历键值对的方式:

Set<Map.Entry<K,V>> entrySet();

//返回此映射中包含的映射关系的Set视图

该方法返回值是Set集合,里面装的是Entry接口类型,即将映射关系装入Set集合。

实现步骤:

1,调用Map集合中的entrySet()方法,将集合中的映射关系对象存储到Set集合中

2,迭代Set集合

3,获取Set集合的元素,是映射关系的对象

4,通过映射关系对象的方法,getKey()和getValue(),获取键值对

补充知识:【JAVA】Map集合(映射集合)、键值对的概念&集合对象的取和放

Map集合

Map集合的作用就是为了快速查找,他里面的集合我们就可以理解为哈希表,且哈希表存东西最好使用键和值。这里要注意的是,Map集合和Collection集合是并列的关系,不存在继承关系。

注:哈希表就是稀疏数组,因为他虽然是数组,但并不是每个索引都用上了,即位置没有存满,浪费了许多空间。

键值对

Map存储时一般都需要两个东西,我们把哈希表里的每个东西叫做Entry对象,另外表外有一个Entry接口。这个接口里定义了两个方法——key(键)和value(值)。

为什么是分为键和值两部分呢?

因为,我们拿键的哈希码来计算我们所要存储的索引,查找也一样通过键来查找。键也是对象,每个对象都有一个HasCode。且HasCode主要是用来计算数组的索引的。而且用键值对查找,其查找速度非常快。

但是,这里要注意的是,有的时候,我们拿值去保存哈希码的话,可能不是太好。我们希望去找特定的数据类型,专门拿某种类型来计算哈希码。

将对象放进集合

集合先将键和值封装成Entry,然后根据键算出哈希码的索引,然后将计算好的Entry对象放到计算出来的那个索引的位置上。

Map m = new HashMap();
m.put("abc", new Student(2000, "孙悟空", 'm'));
m.put("bcd", new Student(2001, "牛魔王",'m'));
m.put("cde", new Student(1999, "紫霞仙子", 'f'));

将集合中的对象取出

通过键所封装的对象的索引位置,来取出Entry对象。但是,最终返回的是值,而不是Entry对象。

Map m = new HashMap();
m.put("abc", new Student(2000, "孙悟空", 'm'));
m.put("bcd", new Student(2001, "牛魔王",'m'));
m.put("cde", new Student(1999, "紫霞仙子", 'f'));

System.out.println(m.get("abc"));

哈希码

这里的哈希码是从Object继承下来的,但是不见子类就合适,因为Object继承下来的哈希码是用地址算的,所以值特别大。如果要往哈希表里面放,那么浪费空间就比较大,所以子类一般会重写。

通过键取Entry对象

返回Entry对象的方法只有一个entrySet方法,而entrySet返回的一定是Set。即它将Entry封装成了Set集合,我们这里返回的是Entry接口的集合。

 System.out.println(m.get("abc"));
 Set s = m.entrySet();
 //迭代Set
 Iterator iter = s.iterator();
 //判断
 while (iter.hasNext()) {
  Map.Entry entry=(Map.Entry)iter.next();
  System.out.println(entry.getKey()+":"+entry.getValue());
 }

遍历所有的值

 //这里不能用Set,因为Set是个无序集,
  //且不能重复,但是,哈希表里的值可以重复。
  //所以,应该用Collection来引用,不敢用Set。
  //values返回的是Collection,
  //且不能返回Set,因为这样会将值给去掉,
  //且值有可能是重复的。
  //键也不能重复,键也返回的是Set。
  Collection c=m.values();
  Iterator it=c.iterator();
  while(it.hasNext()){
  System.out.println(it.next());
  }

拿到所有的键

/**
  * 拿到所有的键
  */
  Set ss=m.keySet();
  Iterator iter1=ss.iterator();
  while(iter1.hasNext()){
  System.out.println(iter1.next());
  }

以上这篇Java中Map集合中的Entry对象用法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • Java8 Map中新增的方法使用总结

    前言 得益于 Java 8 的 default 方法特性,Java 8 对 Map 增加了不少实用的默认方法,像 getOrDefault, forEach, replace, replaceAll, putIfAbsent, remove(key, value), computeIfPresent, computeIfAbsent, compute 和merge 方法.另外与 Map 相关的 Map.Entry 也新加了多个版本的 comparingByKey 和 comparingByVal

  • Java四种遍历Map的方法

    选择适合的最好 import java.util.HashMap; import java.util.Iterator; import java.util.Map; import java.util.Set; /** * Created by song on 2019/1/17. **/ public class MapT { public static void main(String[] args) { Map<Integer,String> map=new HashMap<>

  • 详解Java8合并两个Map中元素的正确姿势

     1. 介绍 本入门教程将介绍Java8中如何合并两个map. 更具体说来,我们将研究不同的合并方案,包括Map含有重复元素的情况. 2. 初始化 我们定义两个map实例 private static Map<String, Employee> map1 = new HashMap<>(); private static Map<String, Employee> map2 = new HashMap<>(); Employee类 public class

  • Java中具有映射关系的容器:数组和Map的区别说明

    映射就意味着有两部分: 存储映射关系的容器是数组和Map集合: 区别: (1)当映射关系中的一方是有序编号时,这个时候要想到数组这种结构: (2)Map不一定需要有序编号,它只能建立对象之间的关系: (3)如果映射的两方没有任何一方是有序的编号,就不能想数组了,这时应该用集合中具备映射关系的容器Map. 注意: (1)Map中键相同时,键值会被覆盖: (2)Map中一个Key可以对应一个集合,因为集合也是一个对象,集合也能往集合中放. (3)Map<int,char>这样写是不正确的,因为,泛

  • Java中Map集合中的Entry对象用法

    Entry: 键值对 对象. 在Map类设计是,提供了一个嵌套接口(static修饰的接口):Entry.Entry将键值对的对应关系封装成了对象,即键值对对象,这样我们在遍历Map集合时,就可以从每一个键值对(Entry)对象中获取对应的键与对应的值. Entry为什么是静态的? Entry是Map接口中提供的一个静态内部嵌套接口,修饰为静态可以通过类名调用. Map集合遍历键值对的方式: Set<Map.Entry<K,V>> entrySet(); //返回此映射中包含的映射

  • java的Map集合中按value值进行排序输出的实例代码

    java的Map集合中按value值进行排序输出的实例代码 import java.util.Arrays; import java.util.Comparator; import java.util.HashMap; import java.util.Map; import java.util.Set; public class Test { public static void main(String[] args) { Map<String ,Integer> map = new Has

  • Java使用entrySet方法获取Map集合中的元素

    本文为大家分享了使用entrySet方法获取Map集合中元素的具体代码,供大家参考,具体内容如下 /*--------------------------------- 使用entrySet方法取出Map集合中的元素: ....该方法是将Map集合中key与value的关系存入到了Set集合中,这个关系的数据类型是Map.Entry ....entrySet方法返回值类型的具体写法为:Set< Map.Entry<KeyType , ValueType> > -----------

  • Java实现过滤掉map集合中key或value为空的值示例

    本文实例讲述了Java实现过滤掉map集合中key或value为空的值.分享给大家供大家参考,具体如下: import java.util.Collection; import java.util.HashMap; import java.util.Iterator; import java.util.Map; import java.util.Set; /** * 过滤掉map集合中key或value为空的值 * @author lmb * @date 2017-3-14 */ public

  • Java中Map集合(接口)的基本方法程序演示

    本文实例为大家分享了Java中Map集合的基本方法程序演示的具体代码,供大家参考,具体内容如下 package pack02; import java.util.*; public class MapDemo { public static void main(String[] args) { //定义一个Map接口类型的引用,指向HashMap类型的对象 Map<String,String> ma = new HashMap<String, String>(); ma.put(&

  • Java使用keySet方法获取Map集合中的元素

    本文为大家分享了Map集合中利用keySet方法获取所有的元素值,供大家参考,具体内容如下 /*--------------------------- Map集合中利用keySet方法获取所有的元素值: ....keySet方法:将Map中的所有key值存入到Set集合中, ....利用Set集合提供的迭代器获取到每一个key值,再通过key值获得相应的value值 ----------------------------*/ package pack03; import java.util.*

  • Java中Map集合的常用方法详解

    目录 1.V put(K key, V value) 2.void putAll(Map<? extends K,? extends V> m) 3.void clear() 4.boolean containsKey(Object key) 5.boolean containsValue(Object value) 6.Set<Map.Entry<K,V>> entrySet() 7.boolean equals(Object o) 8.V get(Object ke

  • 浅谈Map集合中get不存在的key值,会抛出异常吗?

    我就废话不多说了,大家还是直接看代码吧~ public static void main(String[] args) { Map<String, String> a = new HashMap<String, String>(); String string = a.get("a111"); System.out.println(string); } 在Map集合中,get一个不存在的值,不会抛出异常,获得的返回值为null. 补充知识:map中get不存在的

  • 如何去除Java中List集合中的重复数据

    1.循环list中的所有元素然后删除重复 public class duplicatRemoval { public static List removeDuplicate(List list){ for(int i=0;i<list. size()-1;i++){ for(int j=list.size()-1;j>i;j--){ if(list. get(j). equals(list.get(i))){ list.remove(j); } } } return list; } } 总结:

  • JAVA遍历Map集合的几种方法汇总

    今天学习了Map集合的几种方法,尤其是遍历Map集合感觉尤为重要,所以发出来供大家学习和自己复习以用. 众所周知Map集合里存储元素是以键值对的方式存储元素,一个是Key一个是value. 开发过程中推荐使用第四种方法,本文章注释很清晰,仔细看完相信会对你有所帮助的! 方法一: 首先去通过获取迭代器,通过迭代器去遍历集合,获取key然后通过key去获取value,然后就完成了Map集合元素的遍历 public static void main(String[] args) { //使用泛型去创建

随机推荐