zoukankan      html  css  js  c++  java
  • Scala 深入浅出实战经典 第64讲:Scala中隐式对象代码实战详解

    王家林亲授《DT大数据梦工厂》大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频、PPT、代码下载:
    百度云盘:http://pan.baidu.com/s/1c0noOt6
    腾讯微云:http://url.cn/TnGbdC
    360云盘:http://yunpan.cn/cQ4c2UALDjSKy 访问密码 45e2
    土豆:http://www.tudou.com/programs/view/dHz5JKJxurM/
    优酷:http://v.youku.com/v_show/id_XMTI4OTcwNzY2MA==.html?from=s1.8-1-1.2
    爱奇艺:http://www.iqiyi.com/w_19rru5bi79.html#vfrm=2-3-0-1
    腾讯视频:http://v.qq.com/boke/page/k/0/d/k016008s0rd.html
    技术爱好者尤其是大数据爱好者 可以加DT大数据梦工厂的qq群

    DT大数据梦工厂① :462923555
    DT大数据梦工厂②:437123764
    DT大数据梦工厂③ :418110145

    微信公众账号: DT_Spark
    王家林老师微信号: 18610086859
    王家林老师QQ: 1740415547
    王家林老师邮箱: 18610086859@126.com

    本视频由王家林老师, 亲自讲解, 完全通过代码实战把您带人大数据的时代.


    package com.parllay.scala.implicits

    /**
    * Created by richard on 15-8-22.
    * 第64讲:Scala中隐式对象代码实战详解
    *
    * 所谓隐式对象 : 就是用 implicit object 定义的对象,其作用主要表现在 运行时 被调用
    */
    abstract class Template[T] {
    def add (x : T, y:T): T
    }

    abstract class SubTemplate[T] extends Template[T] {
    def unit : T
    }


    object Implicits_Object {

    /**
    * 定义隐式对象
    */
    implicit object StringAdd extends SubTemplate[String] {
    def add (x:String, y: String):String = x concat y
    def unit: String = ""
    }

    /**
    * 定义隐式对象
    */
    implicit object IntAdd extends SubTemplate[Int] {
    def add (x:Int, y: Int) : Int = x + y
    def unit: Int = 0
    }

    /**
    * 在执行sum的时候,首先推断出List的类型为Int.
    * 然后因为有隐式参数implicit m : SubTemplate[T]
    * 会检查当前作用域是否有SubTemplate[T])类型的 implicit object.
    * 如果有并且类型相同,那么就回去执行该隐式对象里的方法.
    */
    def sum[T] (xs : List[T])(implicit m : SubTemplate[T]) : T =
    if (xs.isEmpty) m.unit
    else m.add(xs.head, sum(xs.tail))

    println(sum(List(1,2,3,4,5)))
    println(sum(List("Spark","Scala","Kafka")))

    }

  • 相关阅读:
    Python数据结构与算法—栈
    var_export 和 var_dump
    PHp 下标是 区分大小写的
    和眼睛相处
    css 3 animation
    background-attachment: fixed | attachment 区别
    js 函数表达和函数声明
    function 和 new Function
    lastIndexOf js
    substring substr slice js比较
  • 原文地址:https://www.cnblogs.com/czh-liyu/p/4754885.html
Copyright © 2011-2022 走看看