Scala基础知识

Scala 基础语法

Scala 与 Java 的最大区别是:Scala 语句末尾的分号 ; 是可选的。

我们可以认为 Scala 程序是对象的集合,通过调用彼此的方法来实现消息传递。接下来我们来理解下,类,对象,方法,实例变量的概念:

·对象 -对象有属性和行为。例如:一只狗的状属性有:颜色,名字,行为有:叫、跑、吃等。对象是一个类的实例。

基本语法

Scala 基本语法需要注意以下几点:

·区分大小写-Scala是大小写敏感的,这意味着标识Hello 和 hello在Scala中会有不同的含义。

·类名-对于所有的类名的第一个字母要大写。
如果需要使用几个单词来构成一个类的名称,每个单词的第一个字母要大写。
示例:class MyFirstScalaClass

·方法名称-所有的方法名称的第一个字母用小写。
如果若干单词被用于构成方法的名称,则每个单词的第一个字母应大写。

标识符

Scala 可以使用两种形式的标志符,字符数字和符号。

字符数字使用字母或是下划线开头,后面可以接字母或是数字,符号"$"在 Scala 中也看作为字母。然而以"$"开头的标识符为保留的 Scala 编译器产生的标志符使用,应用程序应该避免使用"$"开始的标识符,以免造成冲突。

空行和空格

一行中只有空格或者带有注释,Scala 会认为其是空行,会忽略它。标记可以被空格或者注释来分割。

换行符

Scala是面向行的语言,语句可以用分号(;)结束或换行符。Scala 程序里,语句末尾的分号通常是可选的。如果你愿意可以输入一个,但若一行里仅 有一个语句也可不写。另一方面,如果一行里写多个语句那么分号是需要的。

Scala

定义包

Scala 使用 package 关键字定义包,在Scala将代码定义到某个包中有两种方式:

第一种方法和 Java 一样,在文件的头定义包名,这种方法就后续所有代码都放在该包中。

Scala 特性

面向对象特性

Scala 是一种高度表达性的编程语言,它结合了面向对象编程和函数式编程的最佳特性。

·类和对象: Scala 支持类和对象,可以定义属性和方法。

·继承和多态: 支持类的继承和多态,可以创建层次结构和重用代码。

·抽象类和特质: 可以定义抽象类和特质(traits),用于定义接口和实现部分行为。

·封装: 支持访问控制修饰符(public、protected、private),实现数据的封装。

函数式编程

·高阶函数: 函数可以作为参数传递给另一个函数,或者从另一个函数返回。

·不可变性: 默认使用不可变数据结构,有助于避免副作用,提高代码的并发安全性。

·模式匹配: 提供强大的模式匹配功能,可以解构复杂数据结构,进行条件判断。

·闭包: 支持闭包,可以捕获并记住其创建时的变量。

扩展性

Scala的设计秉承一项事实,即在实践中,某个领域特定的应用程序开发往往需要特定于该领域的语言扩展。Scala提供了许多独特的语言机制,可以以库的形式轻易无缝添加新的语言结构:

·任何方法可用作前缀或后缀操作符

·可以根据预期类型自动构造闭包。

并发性

·Akka 框架: 基于 Actor 模型,用于构建并发、分布式和容错的应用程序。

·Futures 和 Promises: 提供异步编程的抽象,简化并发任务的管理。

·Scala 并发集合: 提供线程安全的数据结构,方便并发编程。

强大的标准库

·集合框架: 提供丰富的不可变和可变集合类,如List、Set、Map等。

·字符串处理: 提供强大的字符串操作和正则表达式支持。

·IO操作: 支持文件和网络IO操作。

Scala语言的特点

优雅:这是框架设计师第一个要考虑的问题,框架的用户是应用开发程序员,API是否优雅直接影响用户体验。

速度快:Scala语言表达能力强,一行代码抵得上Java多行,开发速度快;Scala是静态编译的,所以速度会快很多。

能融合到Hadoop生态圈:Hadoop现在是大数据事实标准,Spark并不是要取代Hadoop,而是要完善Hadoop生态。JVM语言大部分可能会想到Java,但Java做出来的API太丑,或者想实现一个优雅的API太费劲。 

学习Scala编程语言,为后续学习Spark和Kafka奠定基础。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值