首页
学习
活动
专区
工具
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的时候才能省略,其它方法名都是不可省略名称的。

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

    【Kotlin】apply 内联扩展函数 ( apply 函数原型 | apply 函数示例 | Kotlin 调用 Java API )

    内联扩展函数 apply II . Kotlin 调用 Java API III . apply 内联扩展函数示例 ( 调用 Java API 处理图像 ) I ....内联扩展函数 apply ---- 1 . apply 函数原型 : 泛型 T 类型对象 , 调用 apply 方法 , 后面定义了一个闭包代码块 ; 调用 apply 方法的对象类型是泛型 , 说明任何对象都可以调用该方法...). */ @kotlin.internal.InlineOnly public inline fun T.apply(block: T.() -> Unit): T { contract...函数作用 : 扩展了调用 apply 函数的泛型类型 T 的对象的操作方法 , 等同于为泛型 T 对象定义了一个新的方法 ; 3 . apply 函数调用对象 : 所有的对象都可以调用 apply 函数...函数作用 : 作用 : 扩展了调用 apply 函数的泛型类型 T 的对象的操作方法 , 等同于为泛型 T 对象定义了一个新的方法 特点 : 在 apply

    2.6K20

    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

    1.3K90

    Scala学习(一)Scala特性解析

    在很多地方Scala都很像Java,但是比Java更为函数式编程,这句话主要从三句话就可以理解“一切都是对象”,“一切都是函数”以及“一切都是表达式”三方面理解。...val x = if(a>3)"true"else"false" 所以x的值根据a的大小要么是"true"要么为"false" 在了解了Scala三种特性后正式开启 Scala的类结构 ?...Scala的集合 Scala的集合系统地区分为不可变集合和可变集合。...Scala的可变集合 ? Scala容器和Java容器的互换 Scala的容器可以在转换为Java容器,只要import scala.collection.JavaConverters....Scala中的Try对象 Scala中的Try对象的作用等同与Java中的Try{}catch(){}finally{}结构 Try类有Sucess和Failure两个子类,将有可能会出现异常的代码传入

    95930

    Scala专题系列(三):Scala数组

    一 : 定长数组 如果我们需要声明一个长度不变的数组,可以用scala中的Array,比如: val nums = new Array[Int](10) // 声明一个容量为10个整数的数组,所有元素的初始化为...val arr = Array("hello","world") // 声明一个长度为Array[String] -- 类型是推断出来的 , 如果在声明中已经提供了初始值就不需要new 在JVM中,Scala...Double或其它与java中基本类型对应数组都是基本类型数组,Array(1,2,3,4,5) 在JVM中就是一个Int[] 二 :变长数组:数组缓冲 对于变长数组,Java中有ArrayList Scala...中的等效数据结构为ArrayBuffer import scala.collection.mutable.ArrayBuffer val b = ArrayBuffer[Int]() // 或者new...0到a.length-1 util是RechInt类的方法,返回所有小于(但不包括)上限的数字,比如 0 util 10 返回的是 Range(0,1,2,3,4,5,6,7,8,9) 数组转换 在Scala

    70720

    Scala

    case class   是一个样本类,样本类是一种不可变切可分解类的语法糖,也就是说在构建的时候会自动生成一些语法糖,具有以下几个特点:   1、自动添加与类名一致的构造函数(也就是伴生对象,通过apply...样本类具有以下特性:   (1)⾃动添加与类名一致的构造函数(这个就是前面提到的伴生对象,通过apply⽅法实现),即构造对象时,不需要new;   (2)样本类中的参数默认添加val关键字,即参数不能修改...14、 unapply 和apply⽅法的区别, 以及各自使用场景?   ...一个伴生对象(包含apply和unapply⽅方法)。   ...apply⽅法是为了自动实现样本类的对象,⽆需new关键字。 15、 Scala类型系统中Nil, Null, None, Nothing四个类型的区别?

    18830

    Scala专题系列(一):Scala基础

    在开始之前,先来简要的介绍一下Scala这门语言。...Scala 拥有一套复杂的类型系统, Scala 方言既能用于编写简短的解释脚本,也能用于构建大型复杂系统 一 :Scala的特性: 面向对象特性 Scala是一种纯面向对象的语言,Scala 引入特征...二 :Scala基础 1:变量声明 在Scala中,允许在声明变量是可变的还是不可变(只读)的,不可变的用val关键字声明: val str : String = "hello scala" 上例就是声明了一个...,Scala并不区分基本类型和引用类型,对于它来讲所以得类型都是一个类 在Scala中,我们用方法而不是强制类型转换来做数值类型之间的转换 4:方法声明 Scala 中声明方法的结构如下: def hello...– Scala 推断出的类型比你期望的类型更为宽泛,如 Any。 6:保留字 列出了 Scala 的保留字。

    72540
    领券