scala泛型操作

本文探讨了Scala中的泛型操作,揭示了其作为参数化类型的本质。虽然Scala的泛型采用了Java的泛型擦除模式,类型信息在编译期有效,但在运行时会被擦除。这种机制对编程有何影响,以及如何在实践中使用泛型,是本文的重点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数。scala也采用了Java的泛型擦除模式(erasure),即类型是编译期的,在运行时会被"擦除"的,即运行时看不到类型参数。

package com.test

import scala.collection.immutable.Queue

//对应的3个参数的类型为Triple类中的参数化类型F、S、T
class Triple[F,S,T](val first:F,val second:S,val third:T)

object Test {
  def main(args: Array[String]): Unit = {

    //两种类型参数列表构建Triple类的实例
    //scala支持类型推断,可以推断出各参数的类型,推断出对应的F为String类型、S为Int类型、T为Double类型
    val triple = new Triple("Spark",3,3.1415)

    //明确指定Triple类的3个参数化类型
    val bigData = new Triple[String,String,Char]("Spark","Hadoop",'R')

    //定义了一个泛型参数T的getData方法
    def getData[T](list:List[T]) = list(list.length / 2)
    println(getData(List("Spark","Hadoop",'R')))

    //定义对应的偏应用函数,即部分参数未指定
    val f = getData[Int] _
    println(f(List(1,2,3,4,5,6)))

    //使用Scala类库的泛型集合类Queue来演示泛型的相关操作
    val queue = Queue(1,2,3,4,5)
    val queue_append = queue enqueue 6
    println("queue:" + queue + "\n" + "queue_append:" + queue_append)
  }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值