前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >必知|Scala类型层次结构

必知|Scala类型层次结构

作者头像
Spark学习技巧
发布2020-04-27 19:23:01
1.2K0
发布2020-04-27 19:23:01
举报
文章被收录于专栏:Spark学习技巧

java的除了原始类型的所有类都有一个默认的父类Object,那么scala的统一父类是什么呢?这个是有人在群里问浪尖的一个问题,今天浪尖就给大家讲解一下Scala类型层次结构

在Scala中,所有的值都有类型,包括数值和函数。下图阐述了类型层次结构的一个子集。

1. Scala类型层次结构

Any是所有类型的超类型,也称为顶级类 型。它定义了一些通用的方法如equalshashCodetoStringAny有两个直接子类:AnyValAnyRef

AnyVal代表值类型。有9个预定义的非空的值类型分别是:DoubleFloatLongIntShortByteCharUnitBooleanUnit是不带任何意义的值类型,它仅有一个实例可以像这样声明:()。所有的函数必须有返回,所以说有时候Unit也是有用的返回类型。

AnyRef代表引用类型。所有非值类型都被定义为引用类型。在Scala中,每个用户自定义的类型都是AnyRef的子类型。如果Scala被应用在Java的运行环境中,AnyRef相当于java.lang.Object

这里有一个例子,说明了字符串、整型、布尔值和函数都是对象,这一点和其他对象一样:

代码语言:javascript
复制
val list: List[Any] = List(  "a string",  732,  'c',  true,  () => "an anonymous function returning a string")
list.foreach(element => println(element))

这里定义了一个类型List<Any>的变量list。这个列表里由多种类型进行初始化,但是它们都是scala.Any的实例,所以可以把它们加入到列表中。

下面是程序的输出:

代码语言:javascript
复制
a string732ctrue<function>

2. 类型转换

值类型可以按照下面的方向进行转换:

例如:

代码语言:javascript
复制
val x: Long = 987654321val y: Float = x
val face: Char = '☺'val number: Int = face

转换是单向,下面这样写将不会通过编译。

代码语言:javascript
复制
val x: Long = 987654321val y: Float = xval z: Long = y

你可以将一个类型转换为子类型,这点将在后面的文章介绍。

Nothing和Null

Nothing是所有类型的子类型,也称为底部类型。没有一个值是Nothing类型的。它的用途之一是给出非正常终止的信号,如抛出异常、程序退出或者一个无限循环(可以理解为它是一个不对值进行定义的表达式的类型,或者是一个不能正常返回的方法)。

Null是所有引用类型的子类型(即AnyRef的任意子类型)。它有一个单例值由关键字null所定义。Null主要是使得Scala满足和其他JVM语言的互操作性,但是几乎不应该在Scala代码中使用。我们将在后面的章节中介绍null的替代方案。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-04-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 浪尖聊大数据 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. Scala类型层次结构
  • 2. 类型转换
  • Nothing和Null
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档