每天学一点Scala之apply方法

  • apply方法一般什么地方出现

此方法一般在伴生对象中实现的

  • 目的:

改变了创建伴生类实例的方式,不再通过new的方式,而是直接使用类名() 的方式,scala底层会隐式的调用apply方法

package com.xej.learning.apply

/**
  * apply方法: 就是创建对象时,不再使用new的形式,而是直接使用了类名()的形式
  */
private[apply] class Storm
object Storm{
   //创建伴生类的对象时,会隐式的调用这个的
   def apply: Storm = new Storm()
}
private[apply] class Kafka(val name: String)
object Kafka{
   //由于伴生类的主构造器是有参数的,
   //因此,这里,也必须有参数的
   def apply(name: String): Kafka = new Kafka(name)
}

object ApplyTest {
   def main(args: Array[String]): Unit = {
      val storm = Storm
      val kafka = Kafka("kafka")
   }
}

marathon源码中,同样大量使用了这种形式,如:

时间: 2024-10-05 04:26:00

每天学一点Scala之apply方法的相关文章

Scala 中apply方法的用法

Scala 是构建在 JVM 上的静态类型的脚本语言,而脚本语言总是会有些约定来增强灵活性.关于协议在Python中是挺多的,看看Python的对象协议,有很多很多,如果对Python的对象协议了解(不了解的可以点击此处)的比较深刻的话,其实scala的apply方法也是很好理解的,比如说 Scala 为配合 DSL 在方法调用时有这么一条约定: 在明确了方法调用的接收者的情况下,若方法只有一个参数时,调用的时候就可以省略点及括号.如 "0 to 2",实际完整调用是 "0.

scala的apply方法

package cn.itcast /** * Created by lishas on 2016/8/22. */object ApplyDemo { def apply(): Unit ={ println("apply invoked") } def apply(name:String):String={ name } def apply(name:Int):Int={ println("Int") name } def main(args: Array[St

每天学一点Scala之 方法与函数的区别

每天学一点Scala之implict 隐式参数

什么是隐式参数? 在函数或者方法中,定义一个用implicit关键字修饰的参数:此参数就是隐式参数了.Scala会自动尝试在作用域内查询用implicit修饰的对象,并自动注入参数 Scala查找隐式参数的范围? 一种是当前作用域内可见的var或val定义的隐式变量 一种是隐式参数类型的伴生对象的隐式值 第二个例子

每天学一点Scala之class 构造器

A.scala中类的构造器分为: 主构造器 从构造器 B.  主构造器 参数列表,就写在类名后面: 主构造器内容:类里,除了字段定义和方法定义外的内容,就是主构造器的内容了. C.  从构造器 类里,以def this开头的,都是从构造器, 从构造器的第一行,必须调用主构造器,或者,调用其他从构造器:其实,就是限制,从构造器的第一行,必须是主构造器,主构造器是类的唯一入口点.

每天学一点Scala之内部类

1.  scala 里同样可以定义内部类 2.  每个外部类的对象的内部类,都是不同的类,因此,存数组时,要注意 3.  内部类可以访问外部类的私有属性,反之不行 package com.xej.learning.class_learning /**   * Created by erjun on 2017/8/28.   * 内部类测试   */ private[class_learning] class Kafka{    //定义一个内部类    class InnerKafka(val 

每天学一点Scala之 伴生类和伴生对象

1.  object 相当于class的单个实例,因此,在object里声明的变量都是静态变量,静态方法 2.  在object里声明的变量,都是全局变量,也就是类的公共属性,或者类似于java中父类的属性 3.  object里的构造器,也就是object 内部不在method中的代码,都属于构造器的内容 4. 同样,object的主构造器只会在第一次调用时执行,多次调用,只会执行一次. object使用场景 1.  单例模式 2.  工具类 伴生对象与 伴生类? 如果有一个class,还有一

每天学一点Scala之Scala与Java的区别?

A.Scala是编译型语言,可以随意调用Java代码: B.  Scala函数式编程语言,在scala世界里,函数才是一等公民: 函数可以作为参数进行传递,可以赋值给变量,可以作为返回值进行返回 scala中,具有嵌套函数.匿名函数.高阶函数.偏函数 scala支持闭包

每天学一点Scala之 Currying函数

1.Curring函数 定义? 将原来接收两个参数的一个函数,转换为两个函数,第一个函数接收原先的第一个参数,然后返回接收原先第二个参数的第二个函数. 在函数调用的过程中,就变为了两个函数连续调用的形式 在marathon源码以及Spark的源码中,也有体现,所以对()()这种形式的Curring函数,要理解. 2.例子: object CurryingTest {    def main(args: Array[String]): Unit = {       println("---->