Scala 入坑 之 变量和类型

Scala是一门结合了面向对象和函数式编程的多范式语言,常用于大数据处理项目如Kafka、Spark和Flink。它有类似Java的数值类型,支持变量声明(var)、常量声明(val)和类型转换。表达式和运算符在Scala中是作为方法存在的,而Any是所有类型的超类型。

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

Scala

一、概述

Scala是一门多范式的编程语言,一种类似java的编程语言 [1] ,设计初衷是实现可伸缩的语言 [2] 、并集成面向对象编程函数式编程的各种特性。

为什么要学习scala编程语言?

  • 大数据开发工程师参与大数据领域中的多项开源项目都是scala编写,如:kafka、spark、flink等

  • 下一代,可以替换JAVA编程语言

  • 很多一线互联网公司,正在使用scala语言编写大数据处理应用

二、变量和类型

常用类型

Scala中也有7种数值类型:Byte、Short、Int、Long、Double、Float、Char,以及1个Boolean类型。这些类型都是类,归属于scala.*包。还有一种常用类型为java.lang.String用以声明字符串

表达式

表达式是可计算的语句。如:

1 + 1

你可以使用println来输出表达式的结果。

// println 打印表达式的值 换行
// print 打印表达式的值 不换行
// 引用表达式的值打印
println(1) // 1
println(1 + 1) // 2
println("Hello!") // Hello!
println("Hello," + " world!") // Hello, world!

声明变量

除了可以重新赋值,变量和常量类似。你可以使用var关键字来定义一个变量。

var x = 1 + 1
x = 3 
println(x * x) // 9

注意:scala类型可以被推断,或者你也可以显示地声明类型,语法var x : Int = 10

声明常量(推荐)

你可以使用val关键字来给表达式的结果命名。

val x = 1 + 1
println(x) // 2
x = 3 // 

类型转换

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

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-x6Zvaegx-1680403674219)(null)]

例如:

val x: Long = 987654321
val y: Float = x  // 9.8765434E8 (note that some precision is lost in this case)

val face: Char = '☺'
val number: Int = face  // 9786

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

val x: Long = 987654321
val y: Float = x  // 9.8765434E8
val z: Long = y  // Does not conform

你可以将一个类型转换为子类型

运算符

  • 算术运算符:+、-、*、/、%

  • 关系运算符:==、!=、>、<、>=、<=

  • 逻辑运算符:&&、||、!

  • 位运算符:&(按位与)、|(按位或)、^(异或)、~(取反)、<<、>>、>>>(无符号)

    2  二进制 00000010
    3  二进制 00000011
    2&3=2  00000010   & 同时为1 结果为1  不同为0
    2|3=3  00000011   | 有一个为1 结果为1 不同为0
    2^3=1  00000001	  ^ 相同为0,不同为1
    ~2=-3  11111101   
    2<<1=4   00000100   二进制 向左移动 n位
    2>>1=1
    >>>
    
  • 赋值运算符:=

注意:在Scala中,运算符即是方法。

10 + 1可以写成10.+(1)

Scala类型层次结构

在Scala中,所有的值都有类型,包括数值和函数。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Up7Hfmnz-1680403670066)(null)]

  • Any是所有类型的超类型,也称为顶级类型。它定义了一些通用的方法如equalshashCodetoStringAny有两个直接子类:AnyValAnyRef
  • AnyVal代表值类型。有9个预定义的非空的值类型分别是:DoubleFloatLongIntShortByteCharUnitBooleanUnit(类似于java中的void)是不带任何意义的值类型,它仅有一个实例可以像这样声明:()。所有的函数必须有返回,所以说有时候Unit也是有用的返回类型。
  • AnyRef代表引用类型。所有非值类型都被定义为引用类型。在Scala中,每个用户自定义的类型都是AnyRef的子类型。如果Scala被应用在Java的运行环境中,AnyRef相当于java.lang.Object
  • Nothing是所有类型的子类型,也称为底部类型。没有一个值是Nothing类型的。它的用途之一是给出非正常终止的信号,如抛出异常、程序退出或者一个无限循环(可以理解为它是一个不对值进行定义的表达式的类型,或者是一个不能正常返回的方法)。
  • Null是所有引用类型的子类型(即AnyRef的任意子类型)。它有一个单例值由关键字null所定义。Null主要是使得Scala满足和其他JVM语言的互操作性,但是几乎不应该在Scala代码中使用。我们将在后面的章节中介绍null的替代方案。

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

val list: List[Any] = List(
  "a string",
  732,  // an integer
  'c',  // a character
  true, // a boolean value
  () => "an anonymous function returning a string"
)

list.foreach(element => println(element))

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

下面是程序的输出:

a string
732
c
true
<function>

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

下面是程序的输出:

```scala
a string
732
c
true
<function>
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值