在上一篇《十二步学会Scala-1
》介绍了Scala的变量定义和方法定义,
这一篇将介绍循环和数组
第五步:运行脚本
Scala是一个动态性很强的语言,所以它也像Ruby那样,能够写脚本运行。
新建一个hello.scala的文本文件,
hello.scala 写道
println("Hello, world, from a script!")
打开命令行,并到达hello.scala所在的目录,
cmd 写道
D:\>scala hello.scala
Hello, world, from a script!
D:\>
可以看到很简单,就运行了这个脚本。
第六步: 循环用while, 判断用if
Scala中使用while和java差不多。
写个把输入的参数字符逐个打印出来的小脚本,printargs.scala
printargs.scala 写道
var i = 0
while (i < args.length) {
println(args(i))
i += 1
}
这段脚本会把传入的参数逐个打印出来。
while循环体外定义一个可变的变量i,在循环体内每次加一,直到传入的参数全部打印完毕。
cmd 写道
D:\>scala printargs.scala Scala is fun
Scala
is
fun
D:\>
注意,Scala中不能用i++或++i
if在第一篇的max方法中演示过了,不再重复。
第七步:用foreach和for进行迭代
上面介绍了用while做循环,用过ruby或者喜欢java5新特性的人可能会说,hey,做个循环怎么这么丑?
ruby,java5有foreach,Scala当然也有!
接着上面的需求,用foreach实现把传入的参数打印出来。
建个文本文件,叫pa.scala,里面写上
pa.scala 写道
args.foreach(arg => println(arg))
运行pa.scala你会看到
cmd 写道
D:\>scala pa.scala Scala is easy
Scala
is
easy
D:\>
arg是迭代变量,不需要手工赋值,编译器会把传递给它。
同时编译器会认出arg的类型,所以这里不需要定义类型。
但我觉得如果类型不是一目了然的情况下,最好是定义一下类型,可以使阅读代码的人很轻松。
把arg定义上类型
pa.scala 写道
args.foreach((arg: String) => println(arg))
注意当给变量定义类型的时候,必须要加括号!
这里传给foreach的实际上就是一个匿名方法!
匿名方法的定义是这样的:
方法参数 => 方法体
我们这个传入的匿名方法就是: (arg: String) => println(arg)
很懒的程序员会发现,这里arg好像没什么必要,唯一参数传给唯一的方法体。
在java这样的想法可能是空幻想,但Scala帮你实现了!
我们可以省略成:
pa.scala 写道
args.foreach(println)
就这么少!
Scala还有一个for迭代,可以做更多的事情,但这里只介绍一下它的简单用法。
在ruby中实现上面的打印参数:
ruby 写道
for arg in ARGV # Remember, this is Ruby, not Scala
puts arg
end
用Scala的for来实现
scala 写道
for (arg <- args)
println(arg)
感觉怎么样?这里左箭头<-可以读成in。
在Scala,如果一句话是一行,可以省略分号;如果多个语句放在一行,用分号隔开。
第八步: 数组
数组是定义数据类型很重要很基础的容器。
在Scala里如何使用数组呢?
这次我们的参数由程序定义,并把他们打印出来。
建个文本文件,叫paramswithvalues.scala
paramswithvalues.scala 写道
val greetStrings = new Array[String](3)
greetStrings(0) = "Hello"
greetStrings(1) = ", "
greetStrings(2) = "world!\n"
for (i <- 0 to 2)
print(greetStrings(i))
这里出现了很多Scala的新式武器!
1. 定义数组类型
val greetStrings = new Array[String](3)
val已经介绍过了,表示greetStrings不能再被赋值。
这里Array[String]表示类型,可以读成字符串的数组,它是一个类型,也就是类,所以可以用new去实例化。
括号3表示数组容量是3
2. 数组元素赋值
greetStrings(0) = "Hello"
虽然greetStrings是不可更改的,但数字元素可以。
Scala用小括号代替java的中括号,可能很多java工程师会说:呵,发明新轮子。
其实Scala是被冤枉的。
Scala里所以东西都是对象,数组也不例外。数组赋值其实也是一个方法完成的。
上面的代码会被编译器转换成两个参数的方法:
greetStrings.update(0, "Hello")
当然你也直接这样写上面的赋值:
greetStrings.update(0, "Hello")
greetStrings.update(1, ", ")
greetStrings.update(2, "world!\n")
3. 数组元素读取
在for循环体里面有
print(greetStrings(i))
为什么Scala不用中括号呢?是因为Scala有一套通用规则,会把小括号转换成apply。
所以编译器会得到这样的代码:
print(greetStrings.apply(i))
很魔术?其实只要知道Scala的一些通用规则,很多符号就变得非常简单易懂了。
如果不使用符号,我们的代码同样可以完成:
val greetStrings = new Array[String](3)
greetStrings.update(0, "Hello")
greetStrings.update(1, ", ")
greetStrings.update(2, "world!\n")
for (i <- 0.to(2))
print(greetStrings.apply(i))
这里for循环用了0 to 2,很容易理解,就是从0到2,默认步进1.
当方法参数只有一个的时候,可以不写括号和点,
所以第一循环是这样写就够了:
for (i <- 0 to 2)
to是0的一个方法,
for (i <- 0.to(2))
数组就基本介绍到这里。
接下来一篇将介绍集合类。
未完待续
分享到:
相关推荐
2. **面向对象编程**: Scala是面向对象的语言,支持类、对象、继承、封装和多态性。理解如何创建类、对象,以及如何使用特质(trait)来实现多重继承,是学习Scala OOP的基础。 3. **函数式编程**: Scala也支持函数...
通过阅读和理解这些代码,你可以更好地掌握各种排序算法的原理,并学会在 Scala 中高效地使用它们。 学习和比较这些排序算法对于提升编程能力、理解算法性能至关重要。在实际应用中,应根据数据特性和性能需求选择...
**Scala课程2021春季版** 这门课程聚焦于使用Scala 3进行软件开发,一个强大而富有表现力的...通过这门课程,你将不仅学会Scala 3编程,还能掌握高效构建和管理Scala项目的工具,为你的开发生涯增添一份宝贵的技能。
"如何学会停止担心并爱上单子"这部分描述可能是指学习Scalaz过程中对单子这一抽象概念的理解和应用。 首先,我们需要理解什么是单子(Monad)。在计算机科学中,单子是具有绑定操作(flatMap或>>=)和单位元...
理解这些概念是学习Scala的第一步。 2. **类与对象** Scala中的类和对象是面向对象编程的核心。与Java不同,Scala的类可以有多个构造函数,且一切皆为对象。理解`case class`和`object`的区别对于掌握Scala的面向...
### 编程在Scala:第二版 ...通过本书的学习,读者不仅能掌握Scala语言本身,还能学会如何利用Scala构建可扩展且高性能的应用程序。对于希望深入了解Scala及其生态系统的人来说,这是一本必读的书籍。
通过上述步骤,你已经学会了如何在IDEA中创建Scala项目并打包指定依赖。这对于Scala项目的开发和部署非常有帮助。记得定期更新IDEA版本和Scala插件,以获得最佳的开发体验。此外,合理配置依赖可以显著提高项目的...
Scala编程实战基础教程是一本专为初学者设计的教程,旨在引领读者逐步掌握Scala这门强大的多范式编程语言。Scala结合了面向对象和函数式编程的特性,使其在处理大数据和分布式计算领域,如Apache Spark,表现出色。...
资源包含《Scala编程》第3版英文版和第3版源代码,Scala编程第3版,目前是最新版,支持Scala... 因此学习这本书,不单单是学会了scala语言本身,更重要的是扩展了视野,提升了思维能力和培养了考虑问题的思维方式方法。
学习spark之前,大家必须先学会Scala这门语言,他是spark的基础,这里总结了一下Scala集合的相关知识点
《Scala中的actors》是一本关于在Scala编程语言中使用actors进行编程的教程。Actors提供了一个高级的编程模型,用于构建并发和分布式系统,该模型基于轻量级进程和消息传递。本书的作者之一,Philipp Haller,是...
通过阅读本书,Java开发者将能够快速掌握Scala,理解其独特之处,并学会如何在多语言环境中最佳地利用这门语言。本书尤其适合那些希望在多核时代保持技术竞争力的程序员,因为它不仅提供了理论指导,还包含了大量...
### Scala in Action:深入探索Scala编程语言 #### 标题:Scala in Action ...通过本书的学习,读者不仅能够深入了解Scala的核心概念,还能学会如何利用Scala来解决实际问题,构建高效稳定的软件系统。
《Scala中的函数式编程》一书深入探讨了函数式编程(FP)的核心概念与实践技巧,选择Scala作为实现语言,但其传授的知识可应用于任何支持FP特性的编程语言。本书旨在为读者打下坚实的基础,使其能够编写实质性的函数...
通过上述步骤,我们不仅了解了如何在IDEA 2017版中创建Scala项目并使用Maven管理依赖,还学会了如何利用IDEA的内置功能来提高开发效率。Scala与Spark的结合为大数据处理带来了极大的便利,而IDEA作为一款强大的集成...
本书循序渐进地介绍了Scala的函数式编程基础,虽然篇幅...读者可以学会使用Scala静态语言的强大功能创建简洁、可扩展、高度可并行的代码。对于多核时代JVM上的并发编程,Scala是绝好的工具,而本书是你必不可少的向导。
### Scala in Depth:一本融合函数式编程与面向对象编程的宝典 #### 一、书籍简介 《Scala in Depth》是一本由...通过阅读本书,读者将能够掌握Scala的核心概念,并学会如何将其应用于实际项目中,提升编程技能。
2.易用的数据结构:Scala库提供了许多易于使用的数据结构,如列表、数组、集合等。 3.OOP和FP的结合:Scala允许开发者使用面向对象和函数式编程两种范式。 4.动态和静态类型的结合:Scala是静态类型的,但是它能够在...
这本书的第二版在2016年12月出版,旨在帮助编程新手迅速理解Scala的核心概念和特性,从而能够在实际项目中高效地使用这门语言。 Scala是一种多范式编程语言,它结合了面向对象和函数式编程的思想。该书首先会介绍...