14.scala隐式转换

目录

概述

隐式转换:偷偷的(隐式)对现有功能进行增强(转换)

实践

代码

scala 复制代码
package com.fun.scala

import java.io.File
import scala.io.Source

object ImplicitApp {
  def main(args: Array[String]): Unit = {

    // implicit 2 = to 等价  :定义隐式转换函数
    // implicit def a2B(a:A):B =new B(a.)
    implicit def man2SuperMan(man: Man): SuperMan = new SuperMan(man.name)

    val man = new Man("测试")
    man.fly()

    implicit def file2RichFile(file: File) = new RichFile(file)

    val file = new File("data/wc.data")
    println(file.read())
  }
}

class Man(val name: String)


class SuperMan(val name: String) {
  def fly(): Unit = {
    println(s"$name fly ...")
  }
}

/**
 * 隐式转换 常用命名:RichXxx
 */
class RichFile(val file: File) {
  def read() = Source.fromFile(file.getPath, "utf-8").mkString
}

执行结果

结束

scala隐式转换 至此结束。

相关推荐
欧先生^_^21 小时前
Scala语法基础
开发语言·后端·scala
不要天天开心3 天前
大数据利器:Kafka与Spark的深度探索
spark·scala
不要天天开心3 天前
Kafka与Spark-Streaming:大数据处理的黄金搭档
kafka·scala
什么芮.4 天前
spark-streaming
pytorch·sql·spark·kafka·scala
爱编程的王小美8 天前
Scala 入门指南
开发语言·后端·scala
旋风小飞棍8 天前
spark和hadoop的区别与联系
大数据·开发语言·scala
搞程序的心海12 天前
Flink 编程基础:Scala 版 DataStream API 入门
大数据·flink·scala
不要天天开心13 天前
Spark-SQL与Hive的连接及数据处理全解析
spark·scala
胡萝卜糊了Ohh13 天前
spark-sql
spark·scala