60.Scala中隐式参数实战详解以及隐式参数在Spark中的应用源码解析


隐式参数:函数/方法中参数前有implicit关键字


//7
object Context_Implicits{
  implicit val default : String = "Java"
}

object Param{

   //这里有两个参数列表,属于柯里化
  def print(content : String)(implicit language : String){  //编译器会把带有implicit的参数,作为缺省值/默认值提供给这个函数/方法
    println(content + ":" + language)
  }
}

object Implicit_Parameters_60 {
  def main(args: Array[String]): Unit = {
     Param.print("Spark")("Scala")  //可以直接传入两个参数
     
     import Context_Implicits._
     Param.print("Hadoop")  //也可以不填充第二个参数。编译器会从作用域/静态方法/静态val/object伴生对象中查找隐式参数,作为默认参数

  }
}


参考资料来源于大数据梦工厂 深入浅出scala 第60讲 由王家林老师讲解

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值