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隐式转换 至此结束。

相关推荐
Java水解14 小时前
Scala深入面向对象:类、对象与伴生关系
后端·scala
哈哈很哈哈4 天前
Spark 核心 RDD详解
大数据·分布式·spark·scala
DTS小夏5 天前
Linux 系统 + IDEA+Scala 插件:新手进阶开发指南
linux·scala·intellij-idea
渣渣盟6 天前
Spark核心:单跳转换率计算全解析
大数据·spark·scala·apache
闯闯桑7 天前
Spark 中spark.implicits._ 中的 toDF和DataFrame 类本身的 toDF 方法
大数据·ajax·spark·scala
MOMO陌染10 天前
IDEA环境搭建与输出
scala
闯闯桑12 天前
toDF(columns: _*) 语法
开发语言·前端·spark·scala·apache
q5673152313 天前
无需Python:Shell脚本如何成为你的自动化爬虫引擎?
开发语言·爬虫·python·自动化·scala
渣渣盟15 天前
Spark自定义累加器实现高效WordCount
大数据·spark·scala
IvanCodes15 天前
一、Scala 基础语法、变量与数据类型
大数据·开发语言·scala