• DT梦工厂 第25课 Scala中curring实战详解


    王家林亲授《DT大数据梦工厂》大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频、PPT、代码下载:
    百度云盘:http://pan.baidu.com/s/1c0noOt6 
    腾讯微云:http://url.cn/TnGbdC 
    360云盘:http://yunpan.cn/cQ4c2UALDjSKy 访问密码 45e2
    土豆:http://www.tudou.com/programs/view/dHz5JKJxurM/
    优酷:http://v.youku.com/v_show/id_XMTI4OTcwNzY2MA==.html?from=s1.8-1-1.2
    爱奇艺:http://www.iqiyi.com/w_19rru5bi79.html#vfrm=2-3-0-1
    腾讯视频:http://v.qq.com/boke/page/k/0/d/k016008s0rd.html
    技术爱好者尤其是大数据爱好者 可以加DT大数据梦工厂的qq群

    DT大数据梦工厂① :462923555 
    DT大数据梦工厂②:437123764 
    DT大数据梦工厂③ :418110145

    微信公众账号: DT_Spark
    王家林老师微信号: 18610086859
    王家林老师QQ: 1740415547
    王家林老师邮箱: 18610086859@126.com

    本视频由王家林老师, 亲自讲解, 完全通过代码实战把您带人大数据的时代.

    package com.dt.scala.function

    /**
    * @author iken
    */
    object Curring {

    /*
    * 柯里化是指把原来接受两个函数的参数变成新的接受一个参数的函数的过程。
    * 新的函数返回一个以原有的第二个参数为参数的函数
    * 柯里化的用处:最常见的参数推导
    */
    def main(args : Array[String]){
    /*
    * 1.什么是柯里化?
    * 在下面的函数定义中,multiple函数具有两个参数,我们每次调用的时候
    * 而在multipleOne中同样实现了两个整数相乘的功能,但是multipleOne只有一个参数
    * 那么原本接受两个参数的函数体,现在只接受了一个参数,那么这个函数体就是依赖于第二个参数的新的函数
    * 因此调用multipleOne()()实际是两个步骤:
    * 一:multiple(6)返回一个函数,即 6*y
    * 二。multiple(6)(7)返回 6*7
    */
    def multiple( x:Int, y:Int) = x*y
    def multipleOne( x:Int ) = (y:Int) => x*y
    println( multiple(6,7))
    println( multipleOne(6)(7))
    /*
    * 2.柯里化函数的常规写法如下
    */
    def Curring( x:Int )( y:Int) = x*y

    /*
    * 3. a.corresponds(b)(_.equalsIgnoreCase(_)) 这句实际上包含了柯里化的函数,如下
    * corresponds()()
    * 该函数原始定义:
    * def corresponds[B](that : Seq[B])(p: (A,B)=>Boolean ) :Boolean
    * 在这里,that序列和前提函数p是分开的两个柯里化函数。类型推断器可以分析出B出自that的类型
    */
    val a = Array("Hello", "Spark")
    val b = Array("hello", "spark")
    println( a.corresponds(b)(_.equalsIgnoreCase(_)))
    }
    }

  • 相关阅读:
    状压dp大总结1 [洛谷]
    集训日记(暑期第二周)【真正的集训,真正的考试】
    集训日记(暑期第一周)【6.22始】
    集训模拟赛3【啥也不会的一天】
    P2194 HXY烧情侣【Tarjan】
    6.28-集训模拟赛2【水爆但有进步的半天】
    Linux基础管道管理
    Linux基础进程管理优先级
    awk文本处理
    sed流编辑器
  • 原文地址:https://www.cnblogs.com/iken/p/4765218.html
Copyright © 2020-2023  润新知