1. val和var的区别

val定义的是一个常量,无法改变其内容

scala> val s = 0
s: Int = 0 scala> s = 2
<console>:12: error: reassignment to val
s = 2
^

如果要声明其值可变的变量,可以使用var

scala> var s = 0
s: Int = 0 scala> s = 5
s: Int = 5

在scala中建议使用val,除非你真的想改变他的内容。

2. 基本类型

  • Byte 8位有符号补码整数。数值区间为 -128 到 127
  • Short 16位有符号补码整数。数值区间为 -32768 到 32767
  • Int 32位有符号补码整数。数值区间为 -2147483648 到 2147483647
  • Long 64位有符号补码整数。数值区间为 -9223372036854775808 到 9223372036854775807
  • Float 32位IEEE754单精度浮点数
  • Double 64位IEEE754单精度浮点数
  • Char 16位无符号Unicode字符, 区间值为 U+0000 到 U+FFFF
  • String 字符序列
  • Boolean true或false
  • Unit 表示无值,和其他语言中void等同。用作不返回任何结果的方法的结果类型。Unit只有一个实例值,写成()。
  • Null null 或空引用
  • Nothing Nothing类型在Scala的类层级的最低端;它是任何其他类型的子类型。
  • Any Any是所有其他类的超类
  • AnyRef AnyRef类是Scala里所有引用类(reference class)的基类

3.字符串

3.1 测试字符串是否相等
object Demo{
def main(args: Array[String]): Unit = {
val s = "hello world";
println(s)
val s1 = "Hello";
val s2 = "Hello";
val s3 = "H"+"ello";
println(s1.equals(s2))
println(s1.eq(s3))
println(s1 == s2)
}
} 结果:
hello world
true
true
true Process finished with exit code 0

在Scala中,可以用==方法测试对象的相等性。这与Java中用equals方法比较两个对象不同。

3.2 多行字符串

在Scala中可以使用三个引号创建多行字符串:

object Demo{
def main(args: Array[String]): Unit = {
val s =
"""ohh
haha
nonono
""";
println(s)
}
} 输出结果: ohh
haha
nonono Process finished with exit code 0

结果中可以看到每从第二行起每一行都是以空格开头的,要解决这个问题可以这样做:在多行字符串结尾添加stripMargin方法,并且在第一行后面的所有行以管道符"|"开头:

object Demo{
def main(args: Array[String]): Unit = {
val s =
"""ohh
|haha
|nonono
""".stripMargin;
println(s)
}
} 结果:
ohh
haha
nonono Process finished with exit code 0

如果你不想用"|",你也可以用任意字符:

val s =
"""ohh
/haha
/nonono
""".stripMargin("/");

也会有同样的输出效果。

3.3 字符串中的变量替换

Scala支持在字符串中代换变量。

如果某个字符串需要插入变量,需要在该字符串的前面加上字母"s"标志,然后再字符串中放入变量,每个变量都应该以"$"开头。

object Demo{
def main(args: Array[String]): Unit = {
val name = "xiaoming"
val age = 12
var s = s"$name is a man and he is $age years old"
println(s)
}
} 结果:
xiaoming is a man and he is 12 years old Process finished with exit code 0

在字符串前面添加"s",其实是在创建一个处理字符串字面量。

在字符串字面量中使用表达式

除了把变量放到字符串中外,还可以用花括号把表达式包起来再放到字符串中。根据官方文档,"${}"内可嵌入任何表达式。

val age = 12
println(s"are you kidding me,I always thought you were only ${age + 1} years old")

字符串插值f

如果有一个需求是不改变原变量的前提下给该值添加两位小数,该如何实现呢?

val weight = 111
println(f"ohh dear,I never realized that you have $weight%.2f kilograms") 结果:
ohh dear,I never realized that you have 111.00 kilograms

这个简单的需求繁盛了“f字符串插值”。一个可以通过printf个时候内部字符串的方法。

用这种方法只需要如下两步即可:

1.在字符串前面加上字母f。

2.在变量之后使用printf的格式化操作符。

raw插入符

raw插入符“不会对字符串中的字符进行转义”。

scala> s"hello\nyou"
res0: String =
hello
you scala> raw"hello\nyou"
res1: String = hello\nyou

printf格式化常用字符:

格式化符号 描述
%c 字符
%d 十进制数字
%e 指数浮点数
%f 浮点数
%i 整数
%o 八进制
%s 字符串
%u 无符号十进制
%x 十六进制
%% 打印一个百分号
\% 打印一个百分号
3.4 遍历字符串中的字符

Scala提供了很多方式遍历字符串以及对字符串进行操作,常用的有map,foreach,for,filter。

scala> val s = "you are a kid".map(c => c.toUpper)
s: String = YOU ARE A KID scala> val s = "you are a kid".map(_.toUpper)
s: String = YOU ARE A KID scala> val s = "you are a kid".filter(_ != "\n").map(v => v) ^
s: String = you are a kid val name = "542352354"
for(c <- name){
println(c)
}
name.foreach(println)

4. 数值

Scala内建数值类型包括:

  • Char
  • Byte
  • Short
  • Int
  • Long
  • Float
  • Double
4.1 从字符串到数字

使用String的to*方法。

scala> "200".toInt
res0: Int = 200

如果需要转换的字符串不确定是几进制的,可以通过参数的形式来判断:

val a = Integer.parseInt("01101",2)
println(a) 结果:
13 Process finished with exit code 0
4.2 ++和- -

Scala中没有++ 和 - -这样的操作。所以要是想使用的话只能使用变形的方法:数值类型的可以使用 += 或者是 -= 来操作:

var a = 4
a += 3
println(a)
a -= 5
println(a)
结果:
7
2
4.3 处理大数

Scala提供了BigInt和BigDecimal类来创建一个大数:

var a = BigInt(987654321)
var b = BigDecimal(987654321.543433)
var c = a + a
var d = a * a
var e = b + b
var f = b * b
println(a,b,c,d,e,f) 结果为:
(987654321,987654321.543433,1975308642,975461057789971041,1975308643.086866,975461058863418942.543305425489)

我们看到和java中不一样的是:BigDecimal对象支持所有普通数值类型的操作符。

4.4 生成随机数

Scala中也提供了Random类,用于随机数生成。

var a = Random.nextDouble()
4.5 创建一个数值区间、列表或者数组

使用Int的to方法创建数值区间:

for(i <- 0 to 9){
println(i)
}
结果:
0
1
2
3
4
5
6
7
8
9 Process finished with exit code 0

也可以使用by方法设置步长:

for(i <- 0 to 9 by(2)){
println(i)
}
结果:
0
2
4
6
8 Process finished with exit code 0

不得不说,跟java比是简洁太多了。

5. 控制语句

Scala中的if/else语句和java中的一样使用。

5.1 for循环

Scala中的for循环也很简单,使用"<-"符号来获取循环指针。

var a = Array("liming","hanmeimei","xiaohong")
for(user <- a){
println(user)
} 结果:
liming
hanmeimei
xiaohong Process finished with exit code 0

for循环计数器:

for(i <- 0 to 5){
println(i)
} for(i <- until a.length){
println(i)
}

遍历字符串和数组时,你通常需要使用 0 到 n-1 的区间,这个时候可以使用 until 方法而不是 to 方法。 until 方法返回一个并不包含上限的区间。

封装index和值:

var a = Array("liming","hanmeimei","xiaohong")
for((e,count) <- a.zipWithIndex){
println(e,count)
} 结果: (liming,0)
(hanmeimei,1)
(xiaohong,2) Process finished with exit code 0

遍历Map:

val map = Map("name"->"xiaoming","age"->12,"sex"->1)
for((k,v) <- map){
println(k,v)
} 结果:
(name,xiaoming)
(age,12)
(sex,1)

在for循环中使用多个计数器:

Scala允许在一个for循环中使用多个计数器,这个有点高端:

var i = 1
var j = 1
var k = 1
for(i <- 1 to 3;j <- 1 to 4;k <- 1 to 5){
println(i,j,k)
} 结果: (1,1,1)
(1,1,2)
(1,1,3)
(1,1,4)
(1,1,5)
(1,2,1)
...
(3,4,2)
(3,4,3)
(3,4,4)
(3,4,5)

当我们创建二维数组或者三维数组,就再也不用像java中那样需要三个for循环了。

for循环中嵌入if:

for(i <- 1 to 10 if i % 2 == 0){
println(i)
}

过滤循环条件。

实现break和continue:

Scala中没有break和continue关键字。但是提供了另外的方式来实现该功能,scala.util.control.Breaks类提供了类似的方法:

import util.control.Breaks._

object Demo{
def main(args: Array[String]): Unit = {
breakable{
for( i <- 1 to 10){
println(i)
if(i == 5)
break
}
}
} } 结果: 1
2
3
4
5 Process finished with exit code 0

注意:break和breakable不是关键字而是util.control.Breaks类中的方法。

再来看一下continue是如何执行的:

import util.control.Breaks._

object Demo{
def main(args: Array[String]): Unit = {
for( i <- 1 to 10){
breakable{
if(i == 5){
break
}else{
println(i)
}
}
}
}
} 结果:
1
2
3
4
6
7
8
9
10 Process finished with exit code 0

其实就是换了一种方式使用breakable哈。

Scala中的switch/case:

var i = 0
i match {
case 1 => println(1)
case 2 => println(2)
}

在Scala中使用match函数来表示switch。

在Scala中一个case语句可以匹配多个条件,你可以这样用:

var i = 0
i match {
case 1 | 3 | 5 => println(1)
case 2 | 4 | 6=> println(2)
}

使用"|"分割。对于字符串和其他类型使用的语法是一样的。

Scala中的try/catch

使用方式和java基本一样,只是异常的表达形式与java有区别:

try {
val f = new FileReader("input.txt")
} catch {
case ex: FileNotFoundException =>{
println("Missing file exception")
}
case ex: IOException => {
println("IO Exception")
}
}

异常使用case子句的方式来抛出。

Scala基础语法学习(一)的更多相关文章

  1. 【Scala学习之一】 Scala基础语法

    环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 jdk1.8 scala-2.10.4(依赖jdk1.8) spark ...

  2. Swift基础语法学习总结(转)

    Swift基础语法学习总结 1.基础  1.1) swift还是使用// 和/* */ 来注释,并且/* */允许多行注释. 1.2) swift使用print和println打印,它的传参是一个泛型 ...

  3. Swift基础语法学习总结

    Swift基础语法学习总结Swift高级语法学习总结Swift语法总结补充(一) 1.基础  1.1) swift还是使用// 和/* */ 来注释,并且/* */允许多行注释. 1.2) swift ...

  4. 1.scala基础语法总结

    Scala基础语法总结:Scala 与 Java 的最大区别是:Scala 语句末尾的分号 ; 是可选的.如果一行里写多个语句那么分号是需要的 val s = "菜鸟教程"; pr ...

  5. Python 基础语法学习(第一讲)---类的使用

    [写在前面]:其实自学python有一段时间了,但是一直没想起来要写博客来记录自己的学习,今天才感觉要写点什么让自己学的更扎实一点,所以从今天开始更新python自学系列,希望看见文章的大佬们可以指点 ...

  6. SCALA基础知识学习

    注:本文只说和Java不同的地方. 总结自: Scala详细教程 Scala教程 scala基础语法 Scala 与 Java 的最大区别是:Scala 语句末尾的分号 ";" 是 ...

  7. Java基础语法学习

    Java基础语法学习 1. 注释 单行注释: //单行注释 多行注释: /*多行注释 多行注释 多行注释 多行注释 */ 2. 关键字与标识符 关键字: Java所有的组成部分都需要名字.类名.变量名 ...

  8. Scala系统学习(三):Scala基础语法

    如果您熟悉Java语言语法和编程,那么学习Scala将会很容易.Scala和Java之间最大的句法差异在于行结束字符的分号(;) 是可选的. 当编写Scala程序时,它可以被定义为通过调用彼此的方法进 ...

  9. Spark记录-Scala基础语法

    如果您熟悉Java语言语法和编程,那么学习Scala将会很容易.Scala和Java之间最大的句法差异在于行结束字符的分号(;) 是可选的. 当编写Scala程序时,它可以被定义为通过调用彼此的方法进 ...

随机推荐

  1. 机器学习读书笔记(二)使用k-近邻算法改进约会网站的配对效果

    一.背景 海伦女士一直使用在线约会网站寻找适合自己的约会对象.尽管约会网站会推荐不同的任选,但她并不是喜欢每一个人.经过一番总结,她发现自己交往过的人可以进行如下分类 不喜欢的人 魅力一般的人 极具魅 ...

  2. 【无线安全实践入门】网络扫描和ARP欺骗

    文中可能存在错误操作或错误理解,望大家不吝指正. 同时也希望可以帮助到想要学习接触此方面.或兴趣使然的你,让你有个大概的印象. !阅前须知! 本文是基于我几年前的一本笔记本,上面记录了我学习网络基础时 ...

  3. DStream转为DF的两种方式(突破map时元组22的限制)

    在进行Spark Streaming的开发时,我们常常需要将DStream转为DataFrame来进行进一步的处理, 共有两种方式,方式一: val spark = SparkSession.buil ...

  4. 数字IC前后端设计中的时序收敛(三)--Hold违反的修复方法

    本文转自:自己的微信公众号<数字集成电路设计及EDA教程>(二维码见博文底部) 里面主要讲解数字IC前端.后端.DFT.低功耗设计以及验证等相关知识,并且讲解了其中用到的各种EDA工具的教 ...

  5. Oracle数据库常用的脚本命令(一)

    --连接数据库的命令connect,用于切换连接用户,简写形式conn--语法格式:conn 用户名/密码conn yanln/yanln --显示当前登录的用户show user --执行操作系统的 ...

  6. Event StoryLine Corpus 论文阅读

    Event StoryLine Corpus 论文阅读 本文是对 Caselli T, Vossen P. The event storyline corpus: A new benchmark fo ...

  7. Bzoj 2563: 阿狸和桃子的游戏 题解

    2563: 阿狸和桃子的游戏 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 970  Solved: 695[Submit][Status][Discu ...

  8. Java用Xom生成XML文档

    这个总结源于Java编程思想第四版18.13节的案例: 完整代码地址: Java编程思想:XML 相关Api地址: Attribute Element Document Serializer 由于案例 ...

  9. Kafka FAQ

    报错如下: Unable to read additional data from client sessionid 0x15d2c867a770006 使用的kafka自带的zookeeper,测试 ...

  10. Prim算法与Kruskal(没有代码)

    两个最小生成树算法, 都有一个共同的思想: 这棵树是一点一点长大的; 并且每次生长, 都是贪心的. 不同之处是: Kruscal算法是以边为中心的, 每次找最小的并且有用的边添加到树上; Prim算法 ...