当前位置:网站首页>第42讲:Scala中泛型类、泛型函数、泛型在Spark中的广泛应用
第42讲:Scala中泛型类、泛型函数、泛型在Spark中的广泛应用
2022-07-30 12:20:00 【武念】
泛型:通俗的讲,比如需要定义一个函数,函数的参数可以接受任意类型。我们不可能一一列举所有的参数类型重载(overload)函数。
那么程序引入了一个称之为泛型的东西,这个类型可以代表任意的数据类型。
例如List,在创建List时,可以传入×××、字符串、浮点数等等任意类型。那是因为List在类定义时引用了泛型。
List的定义
sealed abstract class List[+A] extends AbstractSeq[A]
with LinearSeq[A]
with Product
with GenericTraversableTemplate[A, List]
with LinearSeqOptimized[A, List[A]]
with Serializable
其中A就是类型,当然A你可以写成任意的标识符。
泛型应用在类和函数中,代码示例如下:
package com.dt.scala.type_parameterization
//泛型类 F,S,T 是类型,后面引用该类型
class Triple[F,S,T](first: F,second: S,third: T)
object Hello_type_parameterization {
def main(args: Array[String]): Unit = {
//创建一个对象,传入参数类型为 String、Int、Double
val triple1 = new Triple("Spark",3,3.14)
// 可见,定义时使用泛型,在调用时可以根据自己的需要传入任何类型。
//也可以用如下方式创建对象
val triple2 = new Triple[String,String,String]("Spark","Scala","Kafka")
//new 的时候,指定类型。那么传入的参数,必须是指定的类型
// 泛型函数
// 定义一个函数,可以获取各类List的中间位置的值
def getData[T](l: List[T])={
l.take(l.length/2)
}
println(getData(List("a","b","c")))
println(getData(List(1,2,3,4,5,6)))
}
}
边栏推荐
猜你喜欢
Breaking the principle and introducing SQL, what does MongoDB want to do???
爱可可AI前沿推介(7.30)
最基础01/完全背包
Win11打不开exe应用程序怎么办?Win11无法打开exe程序解决方法
New:WebKitX ActiveX :::Crack
AlphaFold预测了几乎所有已知蛋白质!涵盖100万物种2.14亿结构,数据集开放免费用...
概率论的学习整理--番外1:可重复且无次序的计数公式C(n+k-1,k) 的例题 : 同时丢3个骰子,会有多少种情况?答案不是216而是56!
EXCEL解决问题:如何查找目标区域,是否包含指定字符串?
A tutorial on how to build a php environment under win
维护数千规模MySQL实例,数据库灾备体系构建指南
随机推荐
数据湖(十八):Flink与Iceberg整合SQL API操作
为什么说Prometheus是足以取代Zabbix的监控神器?
datax开启hana支持以及dolphinscheduler开启datax任务
Js - 内置对象
和数集团:让智慧城市更智慧,让现实生活更美好
Heshu Group: Make smart cities smarter and make real life better
来n遍剑指--04. 二维数组中的查找
int a=8,a=a++,a? int b=8,b=b+1,b?
Apifox generates interface documentation tutorial and operation steps
概率论的学习整理1: 集合和事件
MySQL中的select,from, join, on where groupby等执行顺序
11 年膨胀 575 倍,微信为何从“小而美”变成了“大而肥”?
Why is Prometheus a monitoring artifact sufficient to replace Zabbix?
即时通讯-改变社交与工作状态的新型软件
OneNote如何修改已有的笔记本为默认的快速笔记?
[SCTF2019]Flag Shop
双击Idea图标打不开——解决办法
Matlab基础(5)——符号运算
云主机上的MongoDB被威胁,开启AUTH认证
OpenHarmony环境搭建报错: ImportError: cannot import name ‘VERSION‘ from ‘hb.__main__‘