Java中Map的merge、compute、computeIfAbsent、computeIfPresent的用法以及使用场景(一)

阅读: 评论:0

Java中Map的merge、compute、computeIfAbsent、computeIfPresent的用法以及使用场景(一)

Java中Map的merge、compute、computeIfAbsent、computeIfPresent的用法以及使用场景(一)

本文由黑壳博客转发

本文来源Java中Map的merge、compute、computeIfAbsent、computeIfPresent的用法以及使用场景(一)

一篇一笑

正文

Java中Map的merge、compute、computeIfAbsent、computeIfPresent的用法以及使用场景(一)
merge,computeIfAbsent使用场景
merge的用法
merge :default V merge(K key, V value,BiFunction<? super V, ? super V, ? extends V> remappingFunction)

merge 的方法有三个参数 第一个是所选map的key,第二个是需要合并的值,第三个是 如何合并,也就是说合并方法的具体实现。

之前的实现
现在我们要做一个操作,把list中的对象,按照属性男女分组,然后把年龄汇总。如果是1.8之前的实现。

    /**  * @author xbmeng  */  public static void main(String[] args) {  //学生的集合  List<Student> students = new ArrayList<>();  students.add(new Student("张三","男",18));  students.add(new Student("李四","男",20));  students.add(new Student("韩梅梅","女",18));  students.add(new Student("小红","女",45));  //声明接收结果的 map  Map<String, Integer> resultMap = new HashMap<>();  for (Student student : students) {  Integer age = (Sex());  if(age != null){  resultMap.Sex(),Age()+age);  }else {  resultMap.Sex(),Age());  }  }  printResult(resultMap);  }  private static void printResult(Map<String, Integer> map){  for (Map.Entry<String, Integer> e : Set()) {  System.out.println("key:"&#Key()+"   "+"value:"&#Value());  }  } 

结果: 
key:女 value:63 
key:男 value:38

1.8中的实现
现在我们要做一个操作,把list中的对象,按照属性男女分组,然后把年龄汇总。如果是1.8之前的实现。

/**  * @author xbmeng  */  public static void main(String[] args) {  //学生的集合  List<Student> students = new ArrayList<>();  students.add(new Student("张三","男",18));  students.add(new Student("李四","男",20));  students.add(new Student("韩梅梅","女",18));  students.add(new Student("小红","女",45));  //声明接收结果的 map  Map<String, Integer> resultMap = new HashMap<>();  for (Student student : students) {  (Sex(), Age(), (a, b) -> b + a);  }  printResult(resultMap);  }  private static void printResult(Map<String, Integer> map){  for (Map.Entry<String, Integer> e : Set()) {  System.out.println("key:"&#Key()+"   "+"value:"&#Value());  }  }  

结果: 
key:女 value:63 
key:男 value:38

computeIfAbsent的用法,map缓冲区
merge :computeIfAbsent(K key, 
Function《? super K, ? extends V> mappingFunction)

merge 的方法有两个参数 第一个是所选map的key,第二个是需要做的操作。这个方法当key值不存在时才起作用。

之前的实现
情景:按照男女分组。

    /**  * @author xbmeng  */  public static void main(String[] args) {  //学生的集合  List<Student> students = new ArrayList<>();  students.add(new Student("张三","男",18));  students.add(new Student("李四","男",20));  students.add(new Student("韩梅梅","女",18));  students.add(new Student("小红","女",45));  //声明接收结果的 map  Map<String, List<Student>> resultMap = new HashMap<>();  for (Student student : students) {  List<Student> s = (Sex());  if(null == s){  s = new ArrayList<>();  resultMap.Sex(),s);  }  s.add(student);  }  System.out.println(resultMap);  }  

结果: 
{女=[Student{name=’韩梅梅’, sex=’女’, age=18}, Student{name=’小红’, sex=’女’, age=45}], 男=[Student{name=’张三’, sex=’男’, age=18}, Student{name=’李四’, sex=’男’, age=20}]}

1.8中的实现
情景:按照男女分组。

   /**  * @author xbmeng  */  public static void main(String[] args) {  //学生的集合  List<Student> students = new ArrayList<>();  students.add(new Student("张三","男",18));  students.add(new Student("李四","男",20));  students.add(new Student("韩梅梅","女",18));  students.add(new Student("小红","女",45));  //声明接收结果的 map  Map<String, List<Student>> resultMap = new HashMap<>();  for (Student student : students) {  List<Student> s = Sex(), k -> new ArrayList<>());  s.add(student);  }  System.out.println(resultMap);  }  

结果: 
{女=[Student{name=’韩梅梅’, sex=’女’, age=18}, Student{name=’小红’, sex=’女’, age=45}], 男=[Student{name=’张三’, sex=’男’, age=18}, Student{name=’李四’, sex=’男’, age=20}]}

compute,computeIfPresent 下一篇博客。

About

欢迎在评论写下你的程序员趣事~~

欢迎加入我们的小组织 ,大家都叫壳叔,期待你的到来。

欢迎关注公众号

这是我们的Group

黑壳家根据地 Q群:200408242

本文发布于:2024-02-04 21:52:43,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170717245759939.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:场景   merge   Map   Java   computeIfPresent
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23