Scala 深入浅出实战经典 第48讲:Scala类型约束代码实战及其在Spark中的应用源码解析

王家林亲授《DT大数据梦工厂》大数据实战视频 Scala 深入浅出实战经典(1-64讲)完整视频、PPT、代码下载:
百度云盘:http://pan.baidu.com/s/1c0noOt6
腾讯微云:http://url.cn/TnGbdC
360云盘:http://yunpan.cn/cQ4c2UALDjSKy 访问密码 45e2
技术爱好者尤其是大数据爱好者 可以加DT大数据梦工厂的qq群

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

微信公众账号: DT_Spark
王家林老师微信号: 18610086859
王家林老师QQ: 1740415547
王家林老师邮箱: [email protected]

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

package com.parllay.scala.type_parameterizitor

/**
 * Created by richard on 15-8-1.
 * 第48讲:Scala类型约束代码实战及其在Spark中的应用源码解析
 */

class Pair_Type[T](val first: T, val second: T) {

  def smaller(implicit ev : T <:< Ordered[T]) =

    if(first < second) first else second

}

object Type_Contraints {

  def main(args: Array[String]) {

    /**
     *  A =:= B 表示A类型等同于B类型
     *  A <:< B 表示A类型是B类型的子类型
     *
     *
     */

    def rocky[T](i:T)(implicit ev : T <:< java.io.Serializable): Unit = {
      println("Life is short, you need spark")
    }

    /**
     * 调用方法的时候, scala会推断出T 类型为String, 然后隐式比较 String 和 Serializable
     *
     * String是Serializable的子类型. 会输出 Life is short, you need spark
     */
    rocky("spark")

    /**
     * 约束的作用1:在特定条件下使用:
     * 比如以下实例Pair_Type class, 这个时候我们可以构建出Pair[File] 实例,
     * 但是只有在真正调用smaller方法的时候才会报错, 因为File 并没有实现Ordered的方法;
     */

    /**
     * 约束的作用2:改进推断类型
     *
     */

    //def firstLast[A,C <: Iterable[A]](it : C) = (it.head, it.last)

    /**
     * 当我们执行如下代码, 推断出的类型为:[Noting, List[int]] 不满足A,C <: Iterable[A]
     * 类型推断器无法判断出A的类型, 因为A,C是在同一个步骤中被匹配到的;
     * 那么解决的办法是 先判断C的类型, 然后判断A的类型.修改为
     */
    def firstLast[A,C](it : C)(implicit env :C <:< Iterable[A]) = (it.head, it.last)

    firstLast(List(1, 2, 3))
  }

}

  

时间: 2024-08-05 19:09:52

Scala 深入浅出实战经典 第48讲:Scala类型约束代码实战及其在Spark中的应用源码解析的相关文章

Scala 深入浅出实战经典 第60讲:Scala中隐式参数实战详解以及在Spark中的应用源码解析

王家林亲授<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/IVN4EuFlmKk/优酷:http://v.youku.com/v_show/id_

Scala 深入浅出实战经典 第65讲:Scala中隐式转换内幕揭秘、最佳实践及其在Spark中的应用源码解析

王家林亲授<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/NGgUD5FBQaA/优酷:http://v.youku.com/v_show/id_

68:Scala并发编程原生线程Actor、Cass Class下的消息传递和偏函数实战解析及其在Spark中的应用源码解析

今天给大家带来的是王家林老师的scala编程讲座的第68讲:Scala并发编程原生线程Actor.Cass Class下的消息传递和偏函数实战解析 昨天讲了Actor的匿名Actor及消息传递,那么我们今天来看一下原生线程Actor及CassClass下的消息传递,让我们从代码出发: case class Person(name:String,age:Int)//定义cass Class class HelloActor extends Actor{//预定义一个Actor  def act()

第43讲:Scala中类型变量Bounds代码实战及其在Spark中的应用源码解析

今天学习了scala的界定,先来看看下面这段代码 //class Pair[T] (val first : T,val second : T)class Pair[T <: Comparable[T]](val first : T,val second : T){  def bigger = if(first.compareTo(second) > 0) first else second} class Pair_Lower_Bound[T](val first : T,val second:

Scala中隐式转换初体验实战详解以及隐式转换在Spark中的应用源码解析之Scala学习笔记-49

package com.leegh.implicits import scala.io.Sourceimport java.io.File /** * @author Guohui Li */ class RichFile(val file: File) { def read = Source.fromFile(file.getPath()).mkString}object Context { implicit def file2RichFile(file: File) = new RichFi

Scala中隐式参数与隐式转换的联合使用实战详解及其在Spark中的应用源码解析之Scala学习笔记-51

package com.leegh.implicits /** * @author Guohui Li */ object Implicit_Conversions_with_Implicit_Parameters { def main(args: Array[String]): Unit = { def bigger[T](a: T, b: T)(implicit ordered: T => Ordered[T]) = if (ordered(a) > b) a else b println

Scala类型约束代码实战及其在Spark中的应用源码解析之Scala学习笔记-39

package com.leegh.parameterization /** * @author Guohui Li */object Type_Contraints { def main(args: Array[String]): Unit = { def rocky[T](i: T)(implicit ev: T <:< java.io.Serializable) { println("Life is too short,you need Spark!") } rock

Scala中Context Bounds代码实战及其在Spark中的应用源码解析之Scala学习笔记-36

package com.leegh.parameterization /** * @author Guohui Li */ class Pair_Ordering[T: Ordering](val first: T, val second: T) { def bigger(implicit ordered: Ordering[T]) = { if (ordered.compare(first, second) > 0) first else second }} object Context_Bo

Scala中类型变量Bounds代码实战及其在Spark中的应用源码解析之Scala学习笔记-34

package com.leegh.parameterization /** * @author Guohui Li */class Pair[T <: Comparable[T]](val first: T, val second: T) { def bigger = if (first.compareTo(second) > 0) first else second} class Pair_Lower_Bound[T](val first: T, val second: T) { def