掌握implicit的用法是阅读Spark源码的基础,也是学习scala其它的开源框架的关键,implicit 可分为:
1.隐式参数
2.隐式转换类型
3.隐式调用函数
package kang
/*
* 1.使用伴生对象,在object中定义implicit
* 2.导入内容 import kang.implicits._
*
* */
class Man(val name :String)
/*object Man{
implicit def man2SuperMan(man:Man) = new SuperMan(man.name)//隐式类型转换,man本身是没有makeMiracle方法的
}*/
object implicits{
implicit def man2SuperMan(man:Man) = new SuperMan(man.name)//隐式类型转换,man本身是没有makeMiracle方法的
}
class SuperMan(val name :String){
def makeMiracle()=println(this.name+" wow,owo,wow!!")
}
object Scala_implicit {
def main(args: Array[String]): Unit = {
import kang.implicits._
val man=new Man("kang")
man.makeMiracle//隐式调用函数
talk("kang先生")("你好!!!")
implicit val content = "hello"//定义隐式参数
talk("kang先生")
}
//隐式参数
def talk(name:String)(implicit content:String)=println("name:"+name+" content:"+content)
}