Scale 编程基础 A(变量声明、基本数据类型、运算符、文件读写、分支与循环、数据结构)

本文深入讲解Scala编程中的变量声明、基本数据类型,包括算术、关系、逻辑运算符,以及文件操作、分支与循环、数据结构(如List、Tuple、Map)和迭代器的使用。了解如何利用类型推断和操作符简化编程,以及如何处理文件I/O和异常处理。
摘要由CSDN通过智能技术生成

Scala:
变量声明、基本数据类型、运算符、文件读写、分支与循环、数据结构(List/Tuple/Range/Vector/Set/Map)与迭代器

  • 变量声明

    • val:是不可变的,在声明时就必须被初始化,而且初始化以后就不能再赋值(赋值报错)
      在这里插入图片描述
      在这里插入图片描述
    • var:是可变的,声明的时候需要进行初始化,初始化以后还可以再次对其赋值
      在这里插入图片描述
    • 显式声明变量的类型
      在这里插入图片描述

    Scala具有“类型推断”能力(类型推断机制),可以自动推断出变量的类型。

    Scala 解释器输入多行代码:
    通常而言,只要Scala解释器推断出你的代码还没有结束,应该延续到下一行,解释器就会在下一行显示一个竖线“|”,可以继续输入剩余的代码,比如,我们要输入表达式val str = “Hello World!”,我们只在命令提示符后面输入“val str = ”然后就回车,显然,这个表达式还没有结束,所以解释器会在下一行显示一个竖线“|”,可以在第2行继续输入”Hello World!”然后回车,解释器就会得到执行结果。
    在这里插入图片描述

  • 基本数据类型

    • Scala的数据类型包括:Byte、Char、Short、Int、Long、Float、Double、Boolean

    注:
    在 Scala,这些类型都是“类”,并且都是包 scala 的成员,如 scala.Int;
    对于字符串,Scala用java.lang.String类来表示字符串,自己并未定义;

    • 字面量
      • 字面量包括整数字面量、浮点数字面量、布尔型字面量、字符字面量、字符串字面量、符号字面量、函数字面量和元组字面量
        在这里插入图片描述
      • Scala允许对“字面量”直接执行方法
        在这里插入图片描述
  • 运算符

    • 算术运算符:在Scala中,可以使用加(+)、减(-) 、乘(*) 、除(/) 、余数(%)等算术操作符,而且,这些操作符就是方法;
      在这里插入图片描述

    注:和Java不同,在Scala中并没有提供++和–操作符,需要采用+=形式
    在这里插入图片描述

    • 关系运算符
      • 大于(>)、小于(<)、大于等于(>=)和小于等于(<=)
        在这里插入图片描述
        在这里插入图片描述
    • 逻辑运算符:&&、||、!
      在这里插入图片描述
    • 位运算符:&、|、^(按位异或)、-(按位取反)
  • 输入输出

    • 输入
      • readInt、readFloat等
        在这里插入图片描述
    • 输出:print println printf (scala.Predef)
    • 插值字符串
      在这里插入图片描述
      在这里插入图片描述
  • 读写文件

    • 写文本文件:java.io.PrintWriter
      在这里插入图片描述
      在这里插入图片描述
      在这里插入图片描述

    new PrintWriter(“output.txt”)中只给出了文件名,并没有给出文件路径,采用相对路径,这时文件就会被保存到启动Scala REPL时的当前目录下;如果我们想把文件保存到一个指定的目录下,就需要给出文件路径。

    • 读文本文件:使用scala.io.Source的getLines方法
      在这里插入图片描述
  • 分支与循环

    • if

      • vim if_try.scala
        在这里插入图片描述
        在这里插入图片描述

      注:
      上述形式代码直接scala filename.scala即可;
      与Java不同的是,Scala中的if表达式的值可以赋值给变量;
      在这里插入图片描述

    • while

      • 1:
        在这里插入图片描述
        在这里插入图片描述
      • 2:do while
        在这里插入图片描述
        在这里插入图片描述
    • for

      • 格式:for (变量<-表达式) 语句块;

      "变量<-表达式"被称为生成器(generator);

      • 例:

        • 打印1到5
          在这里插入图片描述

        注:i 不需要提前进行变量声明

        • 打印1到5之间的奇数
          在这里插入图片描述

        • 打印1到5之间的偶数:守卫(guard)表达式
          在这里插入图片描述

        • Scala 多生成器
          在这里插入图片描述

        • 多生成器&守卫表达式
          在这里插入图片描述

        • for 推导式:yield
          在这里插入图片描述

        带有yield关键字的for循环,被称为“for推导式”。这个概念源自函数式编程,也就是说,通过for循环遍历一个或多个集合,对集合中的元素进行“推导”,从而计算得到新的集合,用于后续的其他处理。

      • Scala无break与continue,解决方法如下
        在这里插入图片描述
        在这里插入图片描述
        break:
        在这里插入图片描述
        continue:
        在这里插入图片描述

  • 异常捕获:Scala异常为不受检异常,try catch

  • 数据结构

    • Array

      • 声明一个长度为3的整型数组并赋值
        在这里插入图片描述

      需要注意的是,在Scala中,对数组元素的应用,是使用圆括号,而不是方括号

      • 声明一个长度为2的字符串数组
        在这里插入图片描述
      • 更加简洁的数组声明和初始化方法
        在这里插入图片描述
      • 多维数组
        在这里插入图片描述
    • Tuple(Scala 元祖)
      在这里插入图片描述

    当需要访问元组中的某个元素的值时,可以通过类似tuple._1、tuple._2、tuple._3这种方式就可以实现

    • List
      在这里插入图片描述
      在这里插入图片描述
      在这里插入图片描述

      注:
      列表有头部和尾部的概念,可以使用arr.head来获取上面定义的列表的头部(第一个),使用arr.tail来获取上面定义的列表的尾部(除第一个);
      我们可以使用::操作(右结合的),在列表的头部增加新的元素,得到一个新的列表;
      Nil表示空列表;

    • Vector
      在这里插入图片描述

    +:与:+

    • Range(在执行for循环时,我们经常会用到数值序列,可以使用range实现)

      • 创建一个从1到5的数值序列,包含区间终点5,步长为1:to
        在这里插入图片描述
        在这里插入图片描述
        在这里插入图片描述
      • 创建一个从1到5的数值序列,不包含区间终点5,步长为1:Until
        在这里插入图片描述
      • 创建一个从1到10的数值序列,包含区间终点10,步长为2:to、by
        在这里插入图片描述
      • 创建一个从0.5到5.6的浮点序列,步长为0.3:to、by
        在这里插入图片描述
    • Set(不重复,无序,以“哈希”方法对元素的值进行组织)

      • 不可变集(缺省情况下创建的是不可变集)
        在这里插入图片描述

      即使是可变类型变量(var),myset还是不可变集:
      myset += “d” 是新的不可变集赋值给可变的变量myset;
      如果使用val,mySet +=“Scala”执行时会报错,因为val声明的变量不可变;

      • 可变集

      如果要声明一个可变集,则需要引入scala.collection.mutable.Set包在这里插入图片描述
      声明myMutableSet为val变量(不是var变量),由于是可变集,因此,可以正确执行myMutableSet += “Cloud Computing”,不会报错,可以这样理解,myMutableSet变量指向的可变集改变了,即加了一个Cloud Computing。

      注意:虽然可变集和不可变集都有添加或删除元素的操作,但是二者有很大的区别。对不可变集进行操作,会产生一个新的集,原来的集并不会发生变化。 而对可变集进行操作,改变的是该集本身。

    • Map

      • 不可变映射(默认情况下创建的是不可变映射)
        在这里插入图片描述

      上面我们定义的是不可变映射,是无法更新映射中的元素的,也无法增加新的元素
      在这里插入图片描述

      • 可变映射(如果需要创建可变映射,需要引入scala.collection.mutable.Map包)
        在这里插入图片描述
      • 循环遍历映射
        • 基本格式:for ((k,v) <- 映射) 语句块
        • 遍历打印key、value
          在这里插入图片描述
        • 遍历打印key
          在这里插入图片描述
        • 遍历打印value
          在这里插入图片描述
  • 迭代器

    • 在Scala中,迭代器(Iterator)不是一个集合,但是,提供了访问集合的一种方法。当构建一个集合需要很大的开销时(比如把一个文件的所有行都读取内存),迭代器就可以发挥很好的作用。
      在这里插入图片描述
      在这里插入图片描述

>>> Scale 编程基础 B(面向对象编程)
>>> Scale 编程基础 C(函数式编程)


中国大学MOOC-厦门大学林子雨-Spark编程基础(侵删)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值