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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第43讲:Scala中类型变量Bounds代码实战及其在Spark中的应用源码解析相关的知识,希望对你有一定的参考价值。

类型变量的界定:

类型变量的上界,类型变量的下界。

上界就是类型必须是界定类型的子类,看如下示例:

package com.dt.scala.type_parameterization

// 我们需要定义一个泛型类Pair,泛型类中有一个bigger方法,用来比较传入的参数
// 此时泛型类型必须是Comparable的子类,我们可以使用 <: 符号来限定传入的类型

class Pair[T <: Comparable[T]](first: T,second:T){
  def bigger ={
    if (first.compareTo(second)>=0) first else second 
  }
}

object Type_variables_Bounds {
  def main(args: Array[String]): Unit = {
    val pair = new Pair("Spark","Hadoop")
    println(pair.bigger)
  }
}


下届:类型必须是界定类型的父类

// 我们使用 >: 符号来做下届限定
class Pair_Lower_Bounds[T](first: T,second:T){
  def replace[R >: T](newFirst: R) = { //R必须是T的父类
      new Pair_Lower_Bounds(newFirst,second)
  }
}


本文出自 “叮咚” 博客,请务必保留此出处http://lqding.blog.51cto.com/9123978/1742149

以上是关于第43讲:Scala中类型变量Bounds代码实战及其在Spark中的应用源码解析的主要内容,如果未能解决你的问题,请参考以下文章

第23讲: Scala高阶函数实战详解

第26讲: Scala中的模式匹配入门实战详解

第28讲:Scala提取器Extractor实战详解

第24讲: Scala中SAM转换实战详解

Scala零基础教学61-80

Scala大数据深度好课Scala大数据操作实战