zoukankan      html  css  js  c++  java
  • scala

    开发中遇到需求:合并两个Map集合对象(将两个对应KEY的值累加)

    先说解决方案:

    ( map1 /: map2 ) { case (map, (k,v)) => map + ( k -> (v + map.getOrElse(k, 0)) ) }

    这特么什么鬼  (╯‵□′)╯""┻━┻☆))>○<) 。。。。。。莫急,且听我慢慢道来。。。。。。。。。


    首先:

    Scala中现有的合并集合操作不能满足这个需求 。

    注意合并后的结果a的G02的值其实是被覆盖掉了。。

    然后:

    说说那个表达式中(a /: b)( ... ) 这部分是什么鬼。这个其实是scala简化的foldLeft函数。

    先看foldLeft

    List(1,2,3).foldLeft(0)((sum,i)=>sum+i)  // 红色部分是初始值,蓝色部分是操作函数

    List(1,2,3).foldLeft(0)((sum,i)=>sum+i)
    可以写成
    (List(1,2,3) foldLeft 0)((sum,i)=>sum+i)
    语法糖
    (0 /: List(1,2,3))(_+_)  

    操作符设计者的脑洞也是够了 - - 开发者绝对是表情帝

    如果接受了这个设定。。。foldRight也可以脑补出来。。 一定是  ((1 to 5) : 100)((i,sum)=> sum-i) .......

    另外。一个例子说明  foldLeft 和 foldRight:

     最后: 

    来说说操作函数中的case  ,这个鬼叫模式匹配 (哦对,模式匹配的时候是要有个大括号包起来的 所以最终结果的操作函数使用大括号包着。)

    Map的折叠函数是依次传入Map的键值对。所以操作函数希望传入的操作数可以是(K,V)形式。。于是用case表达式:(map, (k,v))

    具体模式匹配是什么。。简单说就是scala会尝试将传入的值匹配到case后面表达式的样子(当然这里一定会匹配上,所以没有写case的多余分支)具体什么是“模式匹配”,目前理解尚浅此处暂不深入妄加揣测。

    壹 Try 胜千言 :


    参考

    1) http://stackoverflow.com/questions/7076128/best-way-to-merge-two-maps-and-sum-the-values-of-same-key

    2) http://blog.csdn.net/wsscy2004/article/details/37698013

    3) http://my.oschina.net/sulliy/blog/58266

  • 相关阅读:
    TCO 2013 2A
    matlab 中的fmincon参数设定问题
    一步步写自己SqlHelper类库(四):Connection对象
    珠海立方科技实习总结
    Web Services 应用开发学习笔记(三):XML模式定义
    C#笔记(一):类型,泛型,集合
    Web Services 应用开发学习笔记(二):XML文档类型定义
    一步步写自己SqlHelper类库(三):连接字符串
    一步步写自己SqlHelper类库(二):.NET Framework 数据提供程序
    (Joomla)多功能健康模块
  • 原文地址:https://www.cnblogs.com/tugeler/p/5134862.html
Copyright © 2011-2022 走看看