网站首页 > 教程文章 正文
看到这个标题是不是有点懵逼的状态,心想这孩子是不是傻?自己转自己是不是闹着玩呢。看过这张图,接着往下看。
在日常开发过程中,从一个Map转换为另外一个Map属于基本操作了,那么我们一般怎么去实现 这种场景呢?有什么更简洁省事的方法么?
现在我给你一个简单的场景,Map<String,String> 转换伟Map<String,Integer>,接下来有那些实现方式呢?
首先我们先创建一个Map的公共方法,当然你可以不创建的。
**
* 构造一个Map对象
* @param kv kv
* @return {@link Map}<{@link String}, {@link T}>
*/
private static <T> Map<String, T> newHashMap(Object... kv) {
Map<String, T> ans = new HashMap<>();
for (int i = 0, size = kv.length; i < size; i += 2) {
ans.put(String.valueOf(kv[i]), (T) kv[i + 1]);
}
return ans;
}
方式一:基本的for循环转换
这种方式最容易想到和实现的,直接For循环来转换即可,相信大多数人都是这么写的
public static void common(){
Map<String, String> map = newHashMap("k", "1", "a", "2", "b", "3");
Map<String, Integer> ans = new HashMap<>(map.size());
for (Map.Entry<String, String> entry: map.entrySet()) {
ans.put(entry.getKey(), Integer.valueOf(entry.getValue()));
}
System.out.println(ans);
}
这种方式的优点很明显,实现容易。
第二种方式:基于jdk1.8流式转换
public static void stream() {
Map<String, String> map = newHashMap("k", "1", "a", "2", "b", "3");
Map<String, Integer> ans = map.entrySet().stream().collect(
Collectors.toMap(Map.Entry::getKey, s -> Integer.valueOf(s.getValue())));
System.out.println(ans);
}
使用jdk1.8以上的stream的方式,优点就是代码量相对少,阅读体验不是很好。
第三种方式:Guava的transformValues方式
代码的可读性上,上面两个都不够直观,不能一眼看出这个段代码到底是干啥的。Guava的trasform方式是个比较好的方式,直接上代码
public void transfer() {
Map<String, String> map = newHashMap("k", "1", "a", "2", "b", "3");
Map<String, Integer> ans = Maps.transformValues(map, Integer::valueOf);
System.out.println(ans);
}
是不是很简单,核心逻辑就一行Maps.transformValues(map, String::valueOf)
看了这么多其实吧我还是想让大家自己动手写一个工具类,这样是不是才高大上,符合你的气质。
第四种方式:泛型接口转换
/**
* 变换
*
* @param map 原始集合数据
* @param func 函数
* @return {@link Map}<{@link K}, {@link V}>
*/
public static <K, T, V> Map<K, V> transform(Map<K, T> map, Function<T, V> func) {
Map<K, V> mapnew = new HashMap<>(map.size());
//普通方式,这种方式我先注释掉
// for (Map.Entry<K, T> ktEntry : map.entrySet()) {
// mapnew.put(ktEntry.getKey(), func.apply(ktEntry.getValue()));
// }
//jdk1.8方式都可以
map.forEach((key,value)->mapnew.put(key,func.apply(value)));
return mapnew;
}
下面是这几种方式的通过main方法调用:
public static void main(String[] args) {
//newHashMap("k", 1, "a", 2, "b", 3).forEach((key,value)->{System.out.println("key="+key+" value="+value);});
//普通方式调用
common();
//stream方式
stream();
//guava提供的方式
transfer();
//自己写的工具类
Map<String, String> map = newHashMap("k", "1", "a", "2", "b", "3");
transform(map,Integer::valueOf);
}
用泛型接口方式要转换Map<String,User> 转Map<String,Tuser> 是不是也很简单,但是你需要自己实现像Integer:valueOf的方法,想想怎么调用呢?
总结:这几个小代码是不是能满足你的场景需要。
- 上一篇: 如何设计一个高性能的缓存系统
- 下一篇: Java程序员必看:面试官最爱问的那些算法题
猜你喜欢
- 2025-04-27 Java程序员,一周Python入门:数组,元组,集合,集合,字典
- 2025-04-27 redis Scan 踩坑记 key的模糊匹配
- 2025-04-27 Java开发面试官终结者!HashMap高频面试题总结,务必拿下
- 2025-04-27 内存溢出OutOfMemoryError科普系列一
- 2025-04-27 关于API接口的签名和权鉴,你知道多少?
- 2025-04-27 Java学习总结 2020/4/8
- 2025-04-27 LinkedHashMap源码分析及LRU实现原理
- 2025-04-27 揭秘HashMap扩容机制:为何应用变慢,如何彻底解决问题?
- 2025-04-27 Java 面试笔记之 HashMap 和 ConcurrentHashMap
- 2025-04-27 架构篇-一分钟掌握可扩展架构
- 最近发表
- 标签列表
-
- location.href (44)
- document.ready (36)
- git checkout -b (34)
- 跃点数 (35)
- 阿里云镜像地址 (33)
- qt qmessagebox (36)
- md5 sha1 (32)
- mybatis plus page (35)
- semaphore 使用详解 (32)
- update from 语句 (32)
- vue @scroll (38)
- 堆栈区别 (33)
- 在线子域名爆破 (32)
- 什么是容器 (33)
- sha1 md5 (33)
- navicat导出数据 (34)
- 阿里云acp考试 (33)
- 阿里云 nacos (34)
- redhat官网下载镜像 (36)
- srs服务器 (33)
- pico开发者 (33)
- https的端口号 (34)
- vscode更改主题 (35)
- 阿里云资源池 (34)
- os.path.join (33)