本篇文章首发于头条号Scala快速入门 - 基础语法篇,欢迎关注我的头条号和微信公众号“大数据技术和人工智能”(微信搜索bigdata_ai_tech)获取更多干货,也欢迎关注我的CSDN博客


Scala是一门多范式编程语言,集成了面向对象和函数式语言的特性。本篇文章将以代码示例的形式简单介绍一下Scala语言的基础语法。

声明值和变量

// val声明的变量是不可变的
val str1 = "Hello World!"
val str2 : String = "Hello World!"
val str3 : java.lang.String = "Hello World!" println(str1)
println(str2)
println(str3) // var声明的变量是可变的
var str5 = "Hello World!"
str5 = "str5 Hello World!" println(str5)

基本数据类型

Scala的数据类型包括:Byte、Char、Short、Int、Long、Float、Double和Boolean。在Scala中,这些类型都是“类”,并且都是包scala的成员,比如,Int的全名是scala.Int。对于字符串,Scala用java.lang.String类来表示字符串。

Scala的字面量包括:整数字面量、浮点数字面量、布尔型字面量、字符字面量、字符串字面量、符号字面量、函数字面量和元组字面量。举例如下:

val i = 123      //123就是整数字面量
val i = 3.14 //3.14就是浮点数字面量
val i = true //true就是布尔型字面量
val i = 'A' //'A'就是字符字面量
val i = "Hello" //"Hello"就是字符串字面量 // Scala允许对“字面量”直接执行方法
5.toString() //产生字符串"5"
"abc".intersect("bcd") //输出"bc"

操作符

Scala的常用操作符:加(+)、减(-) 、乘(*) 、除(/) 、余数(%)、大于(>)、小于(<)、大于等于(>=)和小于等于(<=)等,这些操作符就是方法。

Scala的操作符就是方法,a 方法 ba.方法(b)是等价的,前者是后者的简写形式,这里的+是方法名,是Int类中的一个方法。

// 下面三种写法的输出结果都是8
val sum1 = 5 + 3
val sum2 = (5).+(3)
val sum2 = 5.+(3)

控制结构

if条件表达式

val x = 6
if (x > 0) {
println("x = " + x)
} else {
println("x = " + x)
} val x = 3
if (x > 0) {
println("x = " + x)
} else if (x == 0) {
println("x = 0")
} else {
println("x = " + x)
} // Scala中的if表达式的值可以赋值给变量
val a = if (x > 0) 1 else -1

while循环

var i = 9
while (i > 0) {
i -= 1
printf("i is %d\n", i)
} var i = 0
do {
i += 1
println(i)
} while (i < 5)

for循环

// for Range
// Range可以是一个数字区间表示 i to j ,或者 i until j,左箭头 <- 用于为变量 x 赋值。
for (a <- 1 to 10) {
println("a = " + a);
}
for (a <- 1 until 10) {
println("a = " + a);
}
for( a <- 1 to 3; b <- 1 to 3){
println( "a = " + a );
println( "Value of b: " + b );
} // 循环集合
var a = 0;
val numList = List(1, 2, 3, 4, 5, 6);
for (a <- numList) {
println("a = " + a);
} // 循环过滤
var a = 0;
val numList = List(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);
for (a <- numList if a != 3; if a < 8) {
println("a = " + a);
} // 使用yield
// 大括号中用于保存变量和条件,retVal是变量,循环中的yield会把当前的元素记下来,保存在集合中,循环结束后将返回该集合。
var a = 0;
val numList = List(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);
var retVal = for {
a <- numList if a != 3; if a < 8
} yield a
for(a <- retVal) {
println("a = " + a);
}

数组

定长数组,就是长度不变的数组,在Scala中使用Array进行声明,如下:

//声明一个长度为3的整型数组,每个数组元素初始化为0
val intValueArr = new Array[Int](3)
//在Scala中,对数组元素的应用,是使用圆括号,而不是方括号,也就是使用intValueArr(0),而不是intValueArr[0],这个和Java是不同的。
intValueArr(0) = 12
intValueArr(1) = 45
intValueArr(2) = 33 //声明一个长度为3的字符串数组,每个数组元素初始化为null
val strArr = new Array[String](3)
strArr(0) = "Flink"
strArr(1) = "Storm"
strArr(2) = "Spark"
for (i <- 0 to 2) println(strArr(i)) //Scala提供了更加简洁的数组声明和初始化方法,如下:
val intValueArr = Array(12, 45, 33)
val strArr = Array("Flink", "Storm", "Spark")
//从上面代码可以看出,都不需要给出数组类型,Scala会自动根据提供的初始化数据来推断出数组的类型。

可变数组

可变数组需要导入包scala.collection.mutable.ArrayBuffer

//导入ArrayBuffer包
import scala.collection.mutable.ArrayBuffer //定义一个可变的数组
val arr : ArrayBuffer[String] = new ArrayBuffer[String]() //在末尾添加一个元素
arr += "Hadoop"
//在末尾添加多个元素
arr += ("Hive", "Hbase")
//在末尾添加一个集合
arr ++= ArrayBuffer("Scala", "Java")
//在指定位置添加元素
arr(1) = "spark"
arr.insert(1, "Flume")
arr.insert(1, "Kafka", "Kylin")
arr.insertAll(1, ArrayBuffer("Hello", "World"))
println(arr) //更新元素
arr(1) = "insistent"
arr.update(2, "Java")
println(arr) //获取指定元素
println(arr(1))
println(arr.apply(2))
println(arr.take(3)) //删除元素
arr -= "insistent"
//删除集合
arr -= ("Java", "Kafka")
arr.remove(1)
//从1处开始删掉三个
arr.remove(1, 3)
//从前往后移除n个元素
arr.trimStart(1)
//从后往前移除n个元素
arr.trimEnd(1)
println(arr) //遍历数组
for (i <- arr) {
print(i + " ")
} //变长数组转成定长数组
arr.toArray
//定长数组转成变长数组
array.toBuffer

Scala快速入门 - 基础语法篇的更多相关文章

  1. Scala快速入门-基础

    HelloWorld 从HelloWorld开始,使用scala IDE编辑器. 新建scala project 新建scala object 编写HelloWorld run as scala ap ...

  2. Java快速入门-01-基础篇

    Java快速入门-01-基础篇 如果基础不好或者想学的很细,请参看:菜鸟教程-JAVA 本笔记适合快速学习,文章后面也会包含一些常见面试问题,记住快捷键操作,一些内容我就不转载了,直接附上链接,嘻嘻 ...

  3. Java快速入门-02-基础篇

    Java快速入门-02-基础篇 上一篇应该已经让0基础的人对 Java 有了一些了解,接一篇更进一步 使用 Eclipse 快捷键 这个老师一般都经常提,但是自己不容易记住,慢慢熟练 快捷键 快捷键作 ...

  4. .NET Core实战项目之CMS 第五章 入门篇-Dapper的快速入门看这篇就够了

    写在前面 上篇文章我们讲了如在在实际项目开发中使用Git来进行代码的版本控制,当然介绍的都是比较常用的功能.今天我再带着大家一起熟悉下一个ORM框架Dapper,实例代码的演示编写完成后我会通过Git ...

  5. Scala快速入门到精通 视频教程 百度云网盘下载地址

    Scala快速入门到精通  视频教程 百度云网盘下载地址 Scala快速入门到精通 下载地址链接:https://pan.baidu.com/s/1bqGIKyF 密码:ojwd

  6. Xamarin XAML语言教程基础语法篇大学霸

    Xamarin XAML语言教程基础语法篇大学霸 前  言 Xamarin是一个跨平台开发框架.它可以用来开发iOS.Android.Windows Phone和Mac的应用程序.使用Xamarin框 ...

  7. scala快速入门之文档注释

    scala快速入门之文档注释 1.在项目栏的目录树中找到该源码,右击点击Show in Explorer, 即可找到该源码的本地路径,在路径中输入cmd 2.执行scaladoc -d  生成文档注释 ...

  8. Scala快速入门(四)——继承、接口

    Scala快速入门(四)--继承.接口 一.继承 1.继承的概念:省略 2.模板: class Person(n:String,a:Int) { var name:String=n var age:I ...

  9. [PowerShell] 快速入门, 基本语法, 常用类型, 函数, .NET 互操作

    PowerShell 快速入门 开始之前, 我们认定你已经有一定的编程基础, 熟悉 .NET 中的类型与对象. 此文章对于 .NET 开发者来说更简单哦! 在 PowerShell 中, 几乎一切都是 ...

随机推荐

  1. http 1.1 状态码定义

    part of Hypertext Transfer Protocol -- HTTP/1.1RFC 2616 Fielding, et al. 10 Status Code Definitions ...

  2. elasticsearch中mapping的_source和store的笔记(转)

    原文地址: https://www.cnblogs.com/zklidd/p/6149120.html 0.故事引入 无意中看到了ES的mapping中有store字段,作为一个ES菜鸡,有必要对这个 ...

  3. 配置Pods和containers--为Containers和Pods分配CPU资源

    指定CPU请求和CPU限制 要为容器指定CPU请求,在容器资源清单中使用resources:requests字段.要指定CPU限制,使用resources:limits. cpu-request-li ...

  4. 文件组 'PRIMARY' 已满 解决办法

    修改一个字段类型时,报的这个错. 此时需要增加次要数据文件 次要数据文件 次要数据文件包含除主要数据文件外的所有数据文件.有些数据库可能没有次要数据文件,而有些数据库则有多个次要数据文件.次要数据文件 ...

  5. [Golang] 消费Kafka的日志提交到ElasticSearch

    0x0 需求 消费Kafka的日志并写入ElasticSearch供查询 0x1 依赖库 golang版Kafka客户端 https://github.com/Shopify/sarama golan ...

  6. jstree:重新加载数据集,刷新树

    true:表示获得一个已经存在的jstree实例 $('#tree').jstree(true).destroy();// 清除树节点 // 重新设置树的JSON数据集 $('#tree').jstr ...

  7. spring boot 2X中@Scheduled实现定时任务及多线程配置

    使用@Scheduled 可以很容易实现定时任务 spring boot的版本 2.1.6.RELEASE package com.abc.demo.common; import org.slf4j. ...

  8. Mysql 添加用户并授所有权

    创建用户并授权GRANT ALL PRIVILEGES ON *.* TO 'caoxiaobo'@'%' IDENTIFIED BY 'Caoxiaobo0917!' WITH GRANT OPTI ...

  9. [Docker] - 不同容器之间相互访问的实现方式(例如:Client 访问 DB)

    部署了两个独立的容器: Container #1 - Web ClientContainer #2 - SQL Server 不同容器间如何互访? 无法从 Container #1 访问到 Conta ...

  10. Python3 - Bytes类型

    Python3 新增 bytes 类型,是指一堆字节的集合,十六进制表现形式,两个十六进制数构成一个 byte ,以 b 开头的字符串都是 bytes 类型. 计算机只能存储二进制,字符.图片.视频. ...