转自:
http://www.java265.com/JavaCourse/202204/2914.html
HashMap简介:
基于哈希表的 Map 接口的实现。此实现提供所有可选的映射操作,并允许使用 null 值和 null 键。(除了非同步和允许使用 null 之外,HashMap 类与 Hashtable 大致相同。)此类不保证映射的顺序,特别是它不保证该顺序恒久不变。 此实现假定哈希函数将元素适当地分布在各桶之间,可为基本操作(get 和 put)提供稳定的性能。迭代 collection 视图所需的时间与 HashMap 实例的“容量”(桶的数量)及其大小(键-值映射关系数)成比例。所以,如果迭代性能很重要,则不要将初始容量设置得太高(或将加载因子设置得太低)
下文笔者讲述使用value找出对应key的方法分享,如下所示:- <strong>实现思路:
- 使用jdk8的stream流中的filter方法
- 对元素进行查找,并找出符合条件的元素
- </strong>
复制代码 例:- 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:我的网站
复制代码 免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |