转自:
http://www.java265.com/JavaCourse/202204/2914.html
HashMap简介:
基于哈希表的 Map 接口的实现。此实现提供所有可选的映射操作,并允许使用 null 值和 null 键。(除了非同步和允许使用 null 之外,HashMap 类与 Hashtable 大致相同。)此类不保证映射的顺序,特别是它不保证该顺序恒久不变。 此实现假定哈希函数将元素适当地分布在各桶之间,可为基本操作(get 和 put)提供稳定的性能。迭代 collection 视图所需的时间与 HashMap 实例的“容量”(桶的数量)及其大小(键-值映射关系数)成比例。所以,如果迭代性能很重要,则不要将初始容量设置得太高(或将加载因子设置得太低)
下文笔者讲述使用value找出对应key的方法分享,如下所示:
实现思路:
使用jdk8的stream流中的filter方法
对元素进行查找,并找出符合条件的元素
例:
package com.java265.other; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.Map.Entry; import java.util.Optional; import java.util.stream.Collectors; public class Test16 { /** * java265.com 示例程序 * * @throws Exception */ public static void main(String[] args) throws Exception { Map<String, String> map = new HashMap<>(); map.put(\"k1\", \"java265.com\"); map.put(\"k2\", \"我的网站\"); map.put(\"k3\", \"我最爱的网站\"); map.put(\"k4\", \"我喜欢的网站\"); // 查找value 等于 我的网站 所对应的key List<Entry<String, String>> list = map.entrySet().stream().filter(m -> m.getValue().equals(\"我的网站\")) .collect(Collectors.toList()); if (Optional.ofNullable(list).isPresent()) { list.forEach(e->{ System.out.println(\"key:\" + e.getKey() + \" value:\" + e.getValue()); }); } } } -----运行以上代码,将输出以下信息---- key:k2 value:我的网站
来源:https://www.cnblogs.com/java265/p/16485830.html
本站部分图文来源于网络,如有侵权请联系删除。