学习
实践
活动
专区
工具
TVP
写文章

scala apply解析

根据维基百科的解释:apply是一个将函数应用于参数的函数。听上去有点绕口。 scala设计的apply方法也是桥接OOP和FP编程。 通用的将,任意的一个函数,都是一个将其应用到参数的过程。 所以我们可以如下写 f.apply(3) image.png 为何调用伴生对象的时候直接调用的是apply方法? 你是否有这个疑问。 万物皆对象 在scala中,所有的东西都是对象,函数也不例外。 回头看apply 严格来讲所有函数都应该遵循apply的方式,我们前面定义的f函数 f.apply(3) 这样写起来很累,所以scala的编译器帮助我们简化了这个过程,只需要我们写 f(3) 它就等价于上面的写法 至此我相信大家理解了这个apply的原理和逻辑了。 在伴生对象当中定义工厂方法的时候只有命名为apply的时候才能省略,其它方法名都是不可省略名称的。

40250
  • 广告
    关闭

    新年·上云精选

    热卖云产品年终特惠,2核2G轻量应用服务器7.33元/月起,更多上云必备产品助力您轻松上云

  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    ScalaScala中的函数

    1、函数的定义与调用 在Scala中定义函数时,需要定义函数的函数名、参数、函数体。 Scala要求必须给出所有参数的类型,但是不一定给出函数返回值的类型,只要右侧的函数体中不包含递归的语句,Scala就可以自己根据右侧的表达式推断出返回类型。 Scala在定义函数时允许指定最后一个参数可以重复(变长参数),从而允许函数调用者使用变长参数列表来调用该函数,Scala中使用"*"来指明该参数为重复参数。 此时需要使用Scala特殊的语法将参数定义为序列,让Scala解释器能够识别。这种语法非常有用!一定要好好注意,在spark的源码中大量地使用到了。 ,Int]{ def apply(x:Int):Int = x+1; } 将函数作为参数进行传递,这种定义的方式我们叫做:高阶函数。

    384100

    js call 和 apply

    前言   call 和 apply 都是为了改变某个函数运行时的 context 即上下文而存在的,换句话说,就是为了改变函数体内部 this 的指向。    call 和 apply二者的作用完全一样,只是接受参数的方式不太一样。 方法定义   apply   Function.apply(obj,args)方法能接收两个参数:     obj:这个对象将代替Function类里this对象   args:这个是数组或类数组,apply call   call方法与apply方法的第一个参数是一样的,只不过第二个参数是一个参数列表   在非严格模式下当我们第一个参数传递为null或undefined时,函数体内的this会指向默认的宿主对象 ,在浏览器中则是window var test = function(){ console.log(this===window); } test.apply(null);//true test.call

    43220

    scala基础学习--scala教程

    翻译自《big data analytics with spark》第二章Programming in Scala scala基础 虽然scala包含了面向对象编程和函数式编程的能力,但是他更侧重函数式编程 写spark程序,只会用到一点点scala的基本功能,所以只需要学一点点scala就可以了。 自带的类型:这些都是类,scala没有类似int、long这样的基本数据类型 Byte、Short、Int、Long、Float、Double、Char、String、Boolean、 变量:不可变变量 +(y) 以上两句作用相同 trait Scala Trait(特征) 类似 Java 的接口+抽象类,可以包括方法和变量,一个类可以继承多个trait(这点像接口) trait Shape {  def } } MapReduce的map和reduce都参考了函数式编程中的map和reduce的思想,scala本身支持函数式编程,所以也包含map和reduce

    45390

    小议如何使用APPLY

    一般又两种形式写法: 第一种格式就是CROSS APPLY。这种格式可以一方面从表或者结果集中的每一行数据中取出几列数值,另一方面将取出的数据作为输入条件得到表的函数值或者表达式。 使用CROSS APPLY 这个操作符将执行一个表值函数为每行关联在 在结果集中的数据,我们用下面的小例子来展示一下效果: image.png 假如你回顾代码,能发现,我使用CROSS APPLY来链接了 使用OUTER APPLY 与CROSS APPLY功能相似。唯一的不同是CROSS APPLY即使没有匹配到任何行在函数中,已然能够链接表中的数据并在本来应该有函数表现的列上填充null。 如图: image.png 使用表值表达式 到目前为止我们仅仅展示了APPLY 在一个结果集和一个表值函数之间的例子。当然它也是能与一个表值表达式一起应用的。 同样的,我们也能对表值表达式使用 OUTER APPLY 来实现外链接。这个例子我就不再列举了,有兴趣的可以自己尝试一下。

    28250

    扫码关注腾讯云开发者

    领取腾讯云代金券