scala学习笔记-scala简介、REPL交互解释器、变量声明、数据类型

1:scala简介
  • scala是运行在 JVM 上的多范式编程语言,同时支持面向对象面向函数编程
  • 早期scala刚出现的时候,并没有怎么引起重视,随着SparkKafka这样基于scala的大数据框架的兴起,scala逐步进入大数据开发者的眼帘。scala的主要优势是它的表达性。
  • 官网地址:http://www.scala-lang.org
2:scala的REPL交互式解释器
  • Scala提供的最重要的一个工具是交互模式(REPL)。REPL是一个交互式解释器,可以即时编译、运行代码并返回结果,方便前期做学习和测试
  • 启动scala解释器,只需要以下几步
    • 按住windows键 + r
    • 输入scala
  • 退出scala解释器
    • 输入 :quit 就可以了
3:scala中声明变量
3.1 :语法格式
val/var 变量名称:变量类型 = 初始值
  • val定义的是不可重新赋值的变量(值不可修改)
  • var定义的是可重新赋值的变量(值可以修改)
  • 注意
    • scala中声明变量是变量名称在前,变量类型在后,跟java是正好相反
    • scala的语句最后不需要添加分号
3.2:演示
#使用val声明变量,相当于java中的final修饰,不能在指向其他的数据了
 val  a:Int = 1
#使用var声明变量,后期可以被修改重新赋值
 var  b:Int = 2
 b=20
#scala中的变量的类型可以显式的声明,也可以不声明,如果不显式的声明这会根据变量的值来推断出来变量的类型(scala支持类型推断)
 val c = 3
3.2:惰性变量
  • Scala中使用关键字lazy来定义惰性变量,实现延迟加载(懒加载)。
  • 惰性变量只能是不可变变量,并且只有在调用惰性变量时,才会去实例化这个变量。
  • 语法格式 :
    lazy val/var 变量名 = 表达式
    
4:scala中数据类型
  • scala中的类型绝大多数和Java一样
基础类型类型说明
Byte8位带符号整数
Short16位带符号整数
Int32位带符号整数
Long64位带符号整数
Char16位无符号Unicode字符
StringChar类型的序列(字符串)
Float32位单精度浮点数
Double64位双精度浮点数
Booleantrue或false
  • 注意下 scala类型与Java的区别
    • scala中所有的类型都使用大写字母开头
    • 整形使用Int而不是Integer
    • scala中定义变量可以不写类型,让scala编译器自动推断
  • scala类型层次结构
    在这里插入图片描述
类型说明
Any所有类型的父类,,它有两个子类AnyRef与AnyVal
AnyVal所有数值类型的父类
AnyRef所有对象类型(引用类型)的父类
Unit表示空,Unit是AnyVal的子类,它只有一个的实例(),它类似于Java中的void,但scala要比Java更加面向对象
NullNull是AnyRef的子类,也就是说它是所有引用类型的子类。它的实例是null, 可以将null赋值给任何对象类型
Nothing所有类型的子类不能直接创建该类型实例,某个方法抛出异常时,返回的就是Nothing类型,因为Nothing是所有类的子类,那么它可以赋值为任何类型
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值