需求背景:
今天需要给多用户发送邮件,但是用户信息是固定的且数量有限,索性直接写死常量池,遍历常量池进行发邮件操作。设计阶段考虑使用map进行数据封装赋值。为了使代码简洁直观,调研了几种java map初始化并赋值的语法。
由于我目前使用的还是java jdk1.8所以还是选择第一种内联方式创建。
对于初始化一个 map
并直接赋值为常量的场景,可以使用以下几种简短写法:
1. 直接内联创建并添加
如果只需要一个 map
,可以直接在 list.add()
方法中初始化:
list<map<string, string>> list = new arraylist<>(); list.add(new hashmap<>() {{ put("companyname", "科技有限公司"); put("loginurl", "https://www.baidu.com/"); put("bcc", "https://www.baidu.com/"); }});
- 优点:减少变量声明。
- 缺点:仍存在匿名内部类问题。
2. 使用双括号初始化 (仅推荐在测试或临时场景中使用)
list<map<string, string>> list = new arraylist<>(); map<string, string> map = new hashmap<>() {{ put("companyname", "科技有限公司"); put("loginurl", "https://www.baidu.com/"); put("bcc", "https://www.baidu.com/"); }}; list.add(map);
- 优点:写法直观,支持可变的
map
。 - 缺点:
- 生成的匿名内部类可能会导致内存泄漏,不推荐在生产代码中使用。
3. 使用 map.of() (java 9+)
list<map<string, string>> list = new arraylist<>(); map<string, string> map = map.of( "companyname", "科技有限公司", "loginurl", "https://www.baidu.com/", "bcc", "https://www.baidu.com/" ); list.add(map);
- 优点:代码简洁,不需要显式调用
put
方法。 - 限制:
map.of()
创建的map
是不可变的,不能再修改其内容。
4. 使用 map.ofentries() (java 9+)
适用于键值对超过 10 个的场景。
list<map<string, string>> list = new arraylist<>(); map<string, string> map = map.ofentries( map.entry("companyname", "科技有限公司"), map.entry("loginurl", "https://www.baidu.com/"), map.entry("bcc", "https://www.baidu.com/") ); list.add(map);
- 优点:支持更多键值对初始化。
- 限制:同样生成的
map
是不可变的。
5. 使用工具类构造
如果初始化 map
是常见需求,可以封装一个工具方法:
public static <k, v> map<k, v> mapof(object... entries) { map<k, v> map = new hashmap<>(); for (int i = 0; i < entries.length; i += 2) { map.put((k) entries[i], (v) entries[i + 1]); } return map; }
调用:
list<map<string, string>> list = new arraylist<>(); map<string, string> map = mapof( "companyname", "科技有限公司", "loginurl", "https://www.baidu.com/", "bcc", "https://www.baidu.com/" ); list.add(map);
- 优点:通用性强,可在不同场景复用。
- 限制:需要额外的工具类支持。
根据场景选择合适的写法,如果所有内容都是常量且不可变,推荐 map.of()
或 map.ofentries()
的写法。
附:java多层map初始化
因为聚合需求,一开始构造了一个四层map,由于放入实例前需要先判断前面的map存不存在,如果不存在则要new新的map,并把数据放进去,一开始直接if else写写了两百多行。
cr之后觉得很丑陋,就寻找简单的方法去重写。首先将map结构重新规划,将一些固定的值从map中去除,将中间两层的键用连接符合并,在输出时再做拆分,这样四层的map就简化成了两层。
针对实例化的问题,使用如下代码:
map<string, map<string, long>> tmpmap = new hashmap<>(); tmpmap.computeifabsent(key, k -> new hashmap<string, long>{{ put("test", 0l); }}) // 没有该键时构建新的map,省去if-else的contains判断 tmpmap.get(key).computeifpresent("test", (string key, string value) -> ++value); // 如果内层map有该键,则值加1,省去先get再put步骤。
在用computeifpresent()方法的时候犯了个错误,一开始写value++,由于lambda表达式相当于匿名内部类,value++会在该行执行以后再增加值,而该行执行后已经退出了lambda范围因而值没变,而++value或者value + 1则能赋值,因而出于保险起见,在编码中应该尽量使用value += 1类似写法。
总结
到此这篇关于java map初始化并赋值的几种简短写法的文章就介绍到这了,更多相关java map初始化赋值内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论