区分常量和变量

常量

变量

写一行代码,写多行代码,终端代码

数据类型

  • byte
  • char
  • short
  • int
  • long
  • float
  • double
  • boolean

 数据类型与java相似,但与java不同的事,在scala中,这些类型都是“类”,并且都是包scala的成员。

比如,int的全名是scala.Int

字面量(literal)

操作符

Scala 是一种多范式编程语言,它支持多种操作符,包括算术操作符、关系操作符、逻辑操作符、位操作符、赋值操作符以及一些特殊的操作符。

以下是一些主要的 Scala 操作符:

  1. 算术操作符

    • +:加法
    • -:减法
    • *:乘法
    • /:除法
    • %:取模(求余数)
  2. 关系操作符
    • ==:等于
    • !=:不等于
    • >:大于
    • <:小于
    • >=:大于或等于
    • <=:小于或等于
  3. 逻辑操作符
    • &&:逻辑与
    • ||:逻辑或
    • !:逻辑非
  4. 位操作符
    • &:按位与
    • |:按位或
    • ^:按位异或
    • ~:按位取反
    • <<:左移
    • >>:带符号右移
    • >>>:无符号右移
  5. 赋值操作符
    • =:赋值
    • +=-=*=/=%=:复合赋值操作符
  6. 其他特殊操作符
    • :::方法调用操作符(实际上是一个方法名,但通常用作操作符)
    • ::::创建一个新的集合,并添加元素到其尾部
    • +::将一个元素添加到集合的尾部
    • ++:连接两个集合
    • --:从集合中移除一个元素
    • in:检查元素是否存在于集合中
    • match:模式匹配操作符
    • =>:在函数定义、映射和偏函数中使用
    • _:通配符,用于忽略某些值或在模式匹配中表示任意值

这些只是 Scala 中操作符的一部分。由于 Scala 的灵活性和多范式特性,还可以自定义操作符,但通常需要遵守一些规则和约定。

 在scala中,操作符等同于方法。

  • 例子:
scala> var x = 2+2
x: Int = 4 scala> var x=1+2
x: Int = 3 scala> var y=1.+(2)
y: Int = 3 scala> var z=1.+(2)
z: Int = 3 scala> println(x == y)
true scala> println(x == z)
true scala> println(y == z)
true
  • 总结:

    a 方法 b 等价于 a.方法(b)

    前者是后者的简写形式。

递增和递减

与java不同,在scala中没有提供++--操作符,如果想要表达递增或者递减,那么可以使用+=,-=

实例:

scala> var num = 0
num: Int = 0 scala> println(num)
0 scala> num += 1 scala> println(num)
1 scala> num += 1 scala> println(num)
2

富包装类

对于基本的数据类型,除了除了以上操作符之外,scala还提供了许多常用运算的方法,只是这些方法不是在基本类里面定义,而是被封装到一个对应的富包装中。

每个对应的类型都有一个对应的富包装类,比如int类型对应的富包装类是RichInt,这些类位于包scala.runtime中。

当对一个基本数据类型的对象调用其富包装类提供的方法,scaka会自动通过隐式转换将该对象转换为对应的富包装类,然后在调用相应的方法。

实例:

scala> 3 max 8
res12: Int = 8
scala> 19.0 max 97
res14: Double = 97.0

range

在scala中,range是一个特殊的集合,可以用来表示一个范围。

在执行for循环时,我们经常会用到数值序列(比如,i的值从1循环到5),这时就可以采用range来简化代码。

range可以支持创建不同数据类型的数值序列

实例:

//步长不可以为0,步长为0,那么数据不会变
scala> 1 to 10 by 0
java.lang.IllegalArgumentException: step cannot be 0.
at scala.collection.immutable.Range.<init>(Range.scala:86)
at scala.collection.immutable.Range$Inclusive.<init>(Range.scala:430)
at scala.collection.immutable.Range$Inclusive.copy(Range.scala:433)
at scala.collection.immutable.Range.by(Range.scala:135)
... 30 elided
//步长为1
scala> 1 to 10 by 1
res16: scala.collection.immutable.Range = Range(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
//步长为2
scala> 1 to 10 by 2
res17: scala.collection.immutable.Range = Range(1, 3, 5, 7, 9)
//步长为3
scala> 1 to 10 by 3
res18: scala.collection.immutable.Range = Range(1, 4, 7, 10) scala>

控制台输入输出语句

为了从控制台读写数据,可以使用以read为前缀的方法,包括:readint,redadouble,readline,readchar,readboolean,readline等。分别对应9中数据类型,其中前8中方式,没有参数,readline可以不提供参数,也可以带一个字符串参数的提示。

所有的函数都属于对象scala.io.StdIn,使用前必须导入,活着直接使用全称进行调用。

实例:

//不导入函数,会报错

scala> var i = readInt()
warning: there was one deprecation warning; re-run with -deprecation for detail
s
java.lang.NumberFormatException: For input string: ";"
at java.base/java.lang.NumberFormatException.forInputString(NumberFormatExcep
tion.java:67)
at java.base/java.lang.Integer.parseInt(Integer.java:588)
at java.base/java.lang.Integer.parseInt(Integer.java:685)
at scala.collection.immutable.StringLike$class.toInt(StringLike.scala:273)
at scala.collection.immutable.StringOps.toInt(StringOps.scala:29)
at scala.io.StdIn$class.readInt(StdIn.scala:110)
at scala.io.StdIn$.readInt(StdIn.scala:229)
at scala.DeprecatedPredef$class.readInt(Predef.scala:440)
at scala.Predef$.readInt(Predef.scala:70)
... 30 elided
//导入函数,不会报错
scala> import io.StdIn._ //S和I都是大写下划线不要忘记
import io.StdIn._ scala> var i = readInt() //回车之后会卡住,等你输入数据之后,回车
i: Int = 5499 scala>

scala还带有c语言风格的格式化字符串的printf()函数

print(),printf(),println()都在对象Predef中定义,该对象默认情况下被所有scala程序引用,因此不需要导入,可以直接使用。

scala> printf("hello")
hello
scala> println("hello")
hello scala> print("hello")
hello
//
scala> var x=102
x: Int = 102
scala> printf("%d",x)
102
scala> print(x)
102
scala> println(x)
102

读写文件

scala需要使用java.io.PrintWriter类来写文件,使用java.io.BufferedReader类来读文件。

默认生成的文件指定路径,如果不是绝对路径,那么默认是当前目录下(启动scala时,所在的路径)。

数组

scala> var name : Array[String] = Array("zhangsan","lisi","wangwu","zhaoliu","qianqi")
name: Array[String] = Array(zhangsan, lisi, wangwu, zhaoliu, qianqi) scala> name
res0: Array[String] = Array(zhangsan, lisi, wangwu, zhaoliu, qianqi) scala> name(0)
res1: String = zhangsan scala> name(1)
res2: String = lisi scala> name(2)
res3: String = wangwu scala> name(3)
res4: String = zhaoliu scala> name(4)
res5: String = qianqi scala> name.head
res6: String = zhangsan scala> name.length
res7: Int = 5 scala> name.tail
res8: Array[String] = Array(lisi, wangwu, zhaoliu, qianqi) scala> name.contains (lisi)
<console>:24: error: not found: value lisi
name.contains (lisi)
^
scala> name.contains("lisi")
res12: Boolean = true scala> name.contains("zhangsan")
res13: Boolean = true

数组整合

scala> val arr=Array(1,2,3)
arr: Array[Int] = Array(1, 2, 3) scala> val arr02=Array(5,6,7)
arr02: Array[Int] = Array(5, 6, 7) scala> val arr3 = arr++arr02
arr3: Array[Int] = Array(1, 2, 3, 5, 6, 7) scala>

数组加range

scala> val arr03 = range(1,20,3)
<console>:22: error: not found: value range
val arr03 = range(1,20,3)
^
//需要导入包
scala> import Array._
import Array._ scala> val arr03 = range(1,20,3)
arr03: Array[Int] = Array(1, 4, 7, 10, 13, 16, 19) scala>

函数

函数由一个def关键字开始,紧接着是函数名称和可选的参数列表,其次是一个冒号":"

scala> def hum(a:Int,b:Int): Int = (a - b)
hum: (a: Int, b: Int)Int scala> hum(5,3)
res15: Int = 2
scala> def add(x: Int,y: Int): Int = {
| var sum = 0;
| sum = x + y;
| return sum;
| }
add: (x: Int, y: Int)Int scala> add(4,5)
res16: Int = 9 scala>
scala> :paste
// Entering paste mode (ctrl-D to finish) object Test {
def jianInt (a:Int,b:Int) :Int = {
var sum:Int = 0
sum = a - b
return sum
}
} // Exiting paste mode, now interpreting. defined object Test scala> Test.jianInt(4,3)
res18: Int = 1 scala>
scala> object Test {
| def Scala1(x:Int,y:Int): Int = {
| 3*x + 2*y
| }
| def Scala3(x:Int,y:Int): Int = {
| 4*x - y
| }
| def Scala4(x:Int,y:Int): Int = {
| Scala1(x,y) + Scala3(x,y)
| }
| }
defined object Test scala> Test.Scala1(1,3)
res0: Int = 9 scala> Test.Scala3(1,3)
res1: Int = 1 scala> Test.Scala4(1,3)
res2: Int = 10 scala>
scala> def rectangle(len:Double)=(hei:Double)=>(len+hei)*2
rectangle: (len: Double)Double => Double scala> val func=rectangle(4)
func: Double => Double = $Lambda$2069/45962859@577c0be6 scala> println(func(5))
18.0

例子

scala> val yidong = Array(1340,1341,1342)
yidong: Array[Int] = Array(1340, 1341, 1342) scala> val liantong = Array(130,131,132,155)
liantong: Array[Int] = Array(130, 131, 132, 155) scala> val dianxin = Array(133,1349,153)
dianxin: Array[Int] = Array(133, 1349, 153)
scala> def id(x:Int) = {
| if(yidong.contains(x)) {
| print("中国移动")
| }else if(liantong.contains(x)) {
| print("中国联通")
| }else if(dianxin.contains(x)) {
| print("中国电信")
| }else {
| print("不是中国号码")}
| }
id: (x: Int)Unit scala> id(133)
中国电信
scala> id(130)
中国联通
scala> id(1340)
中国移动
scala>

scala的基本语法的更多相关文章

  1. Scala进阶之路-Scala的基本语法

    Scala进阶之路-Scala的基本语法 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.函数式编程初体验Spark-Shell之WordCount var arr=Array( ...

  2. IDEA编写 Scala时没有语法检查和错误提示

    #问题描述 在IDEA中写scala程序时,一些明显的语法错误不进行检查,没有像写Java时的红线什么的,当编译运行时,编译失败. https://blog.csdn.net/weizheng1000 ...

  3. Scala的基本语法总结

    Scala的函数: 目前博客园中的代码编辑器中还不支持Scala语言....用的Java代码的存储方式 object TestScala { def main(args: Array[String]) ...

  4. scala系列--基础语法

    Scala 与 Java 的最大区别是:Scala 语句末尾的分号 ; 是可选的. 区分大小写 -  Scala是大小写敏感的,这意味着标识Hello 和 hello在Scala中会有不同的含义. 类 ...

  5. Scala基础语法 (一)

    如果你之前是一名 Java 程序员,并了解 Java 语言的基础知识,那么你能很快学会 Scala 的基础语法. Scala 与 Java 的最大区别是:Scala 语句末尾的分号 ; 是可选的. 我 ...

  6. Scala学习教程笔记一之基础语法,条件控制,循环控制,函数,数组,集合

    前言:Scala的安装教程:http://www.cnblogs.com/biehongli/p/8065679.html 1:Scala之基础语法学习笔记: :声明val变量:可以使用val来声明变 ...

  7. Scala 语法基础

    一 简介 Scala 是一门多范式(multi-paradigm)的编程语言,设计初衷是要集成面向对象编程和函数式编程的各种特性.Scala 运行在Java虚拟机上,并兼容现有的Java程序.Scal ...

  8. Scala基本语法总结(一)

    Scala基本语法总结 时隔快一年了,又捡起scala,不是想学的有多么的精通,只是想把之前遇到的知识点和实践中遇到的重点进行归纳总结,对以后的面试或许有点帮助吧! 一.scala开发环境的配置 我这 ...

  9. scala函数式编程(二) scala基础语法介绍

    上次我们介绍了函数式编程的好处,并使用scala写了一个小小的例子帮助大家理解,从这里开始我将真正开始介绍scala编程的一些内容. 这里会先重点介绍scala的一些语法.当然,这里是假设你有一些ja ...

  10. Scala学习笔记一

    首先是安装Scala 下载Scala进行安装 http://www.scala-lang.org/ 安装好scala后,为scala配置系统环境参数 新建环境变量SCALA_HOME,值为scala安 ...

随机推荐

  1. 精通中间件测试:Asp.Net Core实战指南,提升应用稳定性和可靠性

    引言 在上一章节我们实战了在Asp.Net Core中的项目实战,这一章节讲解一下如何测试Asp.Net Core的中间件. TestServer 还记得我们在集成测试中提供的TestServer吗? ...

  2. 第四課-Channel Study File Reader & File Writer

    示例描述:从数据库中读取数据并过滤转换为HL7并存放到指定目录;然后读取目录中的HL7文件转换为txt文本并存放到指定目录. 首先在F:\MirthConnect\Test目录下创建Out目录存放输出 ...

  3. HarmonyOS NEXT应用开发之使用AKI轻松实现跨语言调用

    介绍 针对JS与C/C++跨语言访问场景,NAPI使用比较繁琐.而AKI提供了极简语法糖使用方式,一行代码完成JS与C/C++的无障碍跨语言互调,使用方便.本示例将介绍使用AKI编写C++跨线程调用J ...

  4. 团队管理|如何提高技术Leader的思考技巧?

    简介: 技术Leader是一个对综合素质要求非常高的岗位,不仅要有解具体技术问题的架构能力,还要具备团队管理的能力,更需要引领方向带领团队/平台穿越迷茫进阶到下一个境界的能力.所以通常来说技术Lead ...

  5. WPF 触摸下如何给 StylusPointCollection 添加点

    本文告诉大家如何在触摸下给 WPF 的 StylusPointCollection 添加新的点 在自己默认创建的 StylusPointCollection 里面添加点是十分简单的,如以下代码,可以非 ...

  6. WPF 已知问题 传入错误数据给到 WriteableBitmap 可能导致渲染线程锁住

    本文记录一个 WPF 已知问题,此问题已经被我修复.传入错误的数据给到 WriteableBitmap 对象,比如调用 WritePixels 时传入错误的 stride 数值,将可能导致渲染线程进入 ...

  7. 2019-10-31-win10-uwp-访问解决方案文件

    title author date CreateTime categories win10 uwp 访问解决方案文件 lindexi 2019-10-31 09:24:18 +0800 2018-2- ...

  8. virutalenvwrapper安装和使用

    目录 virutalenvwrapper安装和使用 目的: 1.安装pip 2.安装virutalenv和virutalenvwrapper 3.配置环境变量 4. 创建虚拟环境 5.列出全部的虚拟环 ...

  9. GCC编译选项含义解析

    GCC 编译 GCC的编译流程分为四个步骤,分别为: 预处理(Pre-Processing) 可以通过gcc -E hello.cc -o hello.i查看中间结果 编译(Compiling) 汇编 ...

  10. 支持4K60帧,高清高帧率远程控制软件

    设计师可以在家远程工作吗?动画制作人员可以远程在家工作吗?视频后期人员可以远程在家工作吗? 相比其他领域,设计.动画.影视视频后期等行业,往往需要高端机运行大型专业软件,一般人家里不具备这个办公条件. ...