Scala基础语法

Scala与JAVA的关系

Scala是基于Java虚拟机,也就是JVM的一门编程语言,所有Scala的代码都需要经过编译为字节码,然后交由Java虚拟机来运行。

所以Scala和JAVA是可以无缝互操作的,Scala可以任意调用Java的代码,这两种语言的关系事非常紧密的。

Scala解释器的使用

  • REPL:Scala解释器也被称为REPL,会快速编译Scala代码为字节码,然后交给JVM来执行。
  • 计算表达式:命令行内,键入Scala代码,解释器会直接返回结果给你(附带变量类型)。
  • 内置变量:res0、res1
  • 自动补全

声明变量

  • val:常量,声明后不可改变其值
  • var:变量,声明后可以修改值

建议使用val,因为在大型复杂的spark分布式系统中,需要大量的网络传输数据,使用var可能会担心值被错误的更改,所以val可以很大程度上增加大型复杂分布式系统的健壮性和安全性。

在JAVA大型复杂系统的研发中,也使用了类似的特性,我们通常会将传递给其他模块/ 组件/ 服务的对象,设计成不可变类(Immutable Class)。在里面也会使用java的常量定义,比如final,从而提高系统的鲁棒性和安全性。

  • 指定变量类型: val name: String = null
  • 声明多个变量:val name1, name2: String = null ; val num1, num2 = 100

数据类型与操作符

  • 基本数据类型:Byte、Char、Short、Int、Long、Float、Double、Boolean, 咋一看与java的基本数据类型的包装类型相同,但是scala没有基本数据类型与包装类型的概念,统一都是类。scala会自己负责基本数据类型和引用数据类型的转化操作。

    • 例如,Scale提供了RichInt、RichDouble、RichChar,RichInt就提供了to函数,1 to 10,此处int先隐式转换为RichInt,然后在调用其to函数。
  • 基本操作符:与java类似
    • 但是,在scala中,这些操作符其实是数据类型的函数,比如1+1, 可以写成 1.+(1)
    • scala中没有提供++ 、--操作符。

函数调用与apply函数

函数调用方式:

scala> import scala.math._
import scala.math._ scala> sqrt(2)
res2: Double = 1.4142135623730951 scala> pow(2, 4)
res3: Double = 16.0 scala> min(3, Pi)
res4: Double = 3.0 scala> max(3, Pi)
res5: Double = 3.141592653589793

注:如果调用函数时不需要传递参数,那么scala允许省略括号。

apply函数:

  • 在Scala的object中,可以声明apply函数。而使用“类名()"的形式,其实就是“类型.apply()”的一种缩写。通常使用这种方法来构造类对象,而不是new。
  • 例如,"hello World"(6), 因为在StringOps类中有def apply(n:Int): Char的函数定义,所以实际上是"hello World".apply(6)的缩写。
  • 例如,Array(1, 2, 3, 4)相当于Array.apply(1, 2, 3, 4)

lazy值

如果一个变量声明为lazy, 则只有第一次使用该变量时,变量对应的表达式才会发生计算。这种特性对于特别耗时的计算操作特别有用,比如打开文件进行IO,进行网络IO等。

scala> import scala.io.Source._
import scala.io.Source._ scala> lazy val lines = fromFile("D://test.txt").mkString
lines: String = <lazy>

即使文件不存在,也不会报错,只有第一次使用变量时会报错

异常处理

Scala中的异常处理与捕获机制与Java是非常相似的。

try{
throw new IllegalArgumentException("x should not be negative")
} catch {
case _: IllegalArgumentException => println("Illegal Argument!")
} finally {
print("release resources!")
} // Exiting paste mode, now interpreting. Illegal Argument!
release resources!

Scala入门系列(一):基础语法的更多相关文章

  1. 快速入门系列--WebAPI--01基础

    ASP.NET MVC和WebAPI已经是.NET Web部分的主流,刚开始时两个公用同一个管道,之后为了更加的轻量化(WebAPI是对WCF Restful的轻量化),WebAPI使用了新的管道,因 ...

  2. [转]快速入门系列--WebAPI--01基础

    本文转自:http://www.cnblogs.com/wanliwang01/p/aspnet_webapi_base01.html ASP.NET MVC和WebAPI已经是.NET Web部分的 ...

  3. C#快速入门笔记(1)——基础语法

    C#快速入门笔记(1)——基础语法 总体框架:

  4. openresty开发系列15--lua基础语法4表table和运算符

    openresty开发系列15--lua基础语法4表table和运算符 lua中的表table 一)table (表)Table 类型实现了一种抽象的"关联数组".即可用作数组,也 ...

  5. openresty开发系列14--lua基础语法3函数

    openresty开发系列14--lua基础语法3函数 一)function (函数) 有名函数: optional_function_scope function function_name( ar ...

  6. openresty开发系列13--lua基础语法2常用数据类型介绍

    openresty开发系列13--lua基础语法2常用数据类型介绍 一)boolean(布尔)布尔类型,可选值 true/false: Lua 中 nil 和 false 为"假" ...

  7. 075 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 07 综合案例-数组移位-主方法功能4的实现

    075 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 07 综合案例-数组移位-主方法功能4的实现 本文知识点:综合案例-数组移位-主方法功能4的实现 说明:因为 ...

  8. 074 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 06 综合案例-数组移位-主方法功能3的实现

    074 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 06 综合案例-数组移位-主方法功能3的实现 本文知识点:综合案例-数组移位-主方法功能3的实现 说明:因为 ...

  9. 073 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 05 综合案例-数组移位-主方法功能1和2的实现

    073 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 05 综合案例-数组移位-主方法功能1和2的实现 本文知识点:综合案例-数组移位-主方法功能1和2的实现 说 ...

  10. 072 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 04 综合案例-数组移位-在指定位置处插入数据方法

    072 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 04 综合案例-数组移位-在指定位置处插入数据方法 本文知识点:综合案例-数组移位-在指定位置处插入数据方法 ...

随机推荐

  1. C++向量(08)

    在数组生存期内,数组的大小是不会改变的.向量是一维数组的类版本,它与数组相似,其中的元素项总是连续存储的,但它和数组不同的是:向量中存储元素的多少可以在运行中根据需要动态地增长或缩小.向量是类模板,具 ...

  2. hadoop集群服务器配置注意事项

    1.使用root账户,一劳记逸,远离权限问题. 2.关闭防火墙,命令:service iptables stop 想永久关闭,命令为:chkconfig iptables off 查看防火墙状态,命令 ...

  3. Windows环境下多线程编程原理与应用读书笔记(2)————面向对象技术

    面向对象技术是学C++需要重点掌握的知识,因为我觉得自己的基础还是比较可以,这一章节的内容就只是粗略的读了一遍,在此就不做过多的笔记.

  4. 使用Apache Commons Email 发生邮件

    Apache Commons Email的Maven依赖 <!-- https://mvnrepository.com/artifact/org.apache.commons/commons-e ...

  5. Android 开发笔记___图像视图__简单截屏

    <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android=&quo ...

  6. HTML学习笔记 CSS文本及字体及连接及列表(a标签使用及缩进) 案例 第七节 (原创)参考使用表

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. Java_String_01_由转义字符串得到其原本字符串

    在开发企业微信电子发票之拉取电子发票接口的时候,微信服务器会发送给我们一个2层的转义字符串,而我们要想得到我们想要的结果,就需要进行一些处理: 反转义+去除首尾双引号. 一.需求 现有一个字符串 st ...

  8. vue-cli 脚手架目录结构说明

    目录结构截图如下 /build 编译配置文件目录,由脚手架自动生成 /config webpack 配置文件目录,由脚手架自动生成 /node_modules node依赖目录,可通过package. ...

  9. 一起写框架-Ioc内核容器的实现-基础功能-ComponentScan支持多包扫描(六)

    实现功能 1.我们看到@ComponentScan注解一个开始定义就是需要支持,扫描多个包,将多个包的类名获取到.现在就实现这个功能. 实现思路 根据传入的字符串数组,获得多个包下的类全限制名. 实现 ...

  10. 动态代理:JDK动态代理和CGLIB代理的区别

    代理模式:代理类和被代理类实现共同的接口(或继承),代理类中存有指向被代理类的索引,实际执行时通过调用代理类的方法.实际执行的是被代理类的方法. 而AOP,是通过动态代理实现的. 一.简单来说: JD ...