第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)
  }
}

标题名称:第43讲:Scala中类型变量Bounds代码实战及其在Spark中的应用源码解析
标题路径:http://bzwzjz.com/article/ipcjsg.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 四川成都网站制作 成都网站设计 网站建设开发 成都企业网站建设公司 营销网站建设 成都企业网站建设 成都网站设计 成都网站制作 高端网站设计 成都网站设计 响应式网站设计 广安网站设计 教育网站设计方案 成都品牌网站建设 企业手机网站建设 网站制作 成都网站设计 企业网站制作 成都网站建设公司 重庆企业网站建设 网站建设 温江网站设计