一、Scala基础语法
1、Scala 与 Java 的最大区别是:Scala 语句末尾的分号 ; 是可选的。
2、在scala中对于大小写都是有要求的:
(1)对于类名:第一个字母要大写,如果需要使用几个单词来构成一个类的名称,每个单词的第一个字母要大写。
(2)对于方法名称:第一个首字母要用小写,如果若干单词被用于构成方法的名称,则每个单词的第一个字母应大写。
3、标识符
Scala 可以使用两种形式的标志符,字符数字和符号。
字符数字使用字母或是下划线开头,后面可以接字母或是数字,符号"$"在 Scala 中也看作为字母
4、注释
Scala分为两种注释与Java一样:多行注释/*.......*/与单行注释//
5、空行与空格
一行中只有空格或者带有注释,Scala 会忽略,可以被空格或者注释来分割。
6、scala包
(1)定义包
Scala 使用 package 关键字定义包,两种方式:
第一种方法:在文件的头定义包名,这种方法就后续所有代码都放在该包中。
第二种方法:可以在一个文件中定义多个包。
(2)引用
Scala 使用 import 关键字引用包。import语句可以出现在任何地方,而不是只能在文件顶部。import的效果从开始延伸到语句块的结束。这可以大幅减少名称冲突的可能性。
二、scala的特性
1、面向对象
(1)类和对象:定义属性和方法
(2)继承和多态:用于创建层次结构和重用代码
(3)抽象类和特质:用于定义接口和实现部分行为
(4)封装:支持访问控制修饰符(public、protected、private),实现数据的封装
2、函数式编程
(1)高阶函数 :两个函数之间的传递和返回
(2)不可变性:有助于避免副作用,提高代码的并发安全性。
(3)模式匹配:有强大的匹配功能
(4)闭包:支持闭包
3、类型系统
1、静态类型
(1)类型推断(2)泛型编程(3)类型系统扩展
2、扩展性
可以以库的形式轻易无缝添加新的语言结构:
(1)任何方法可用作前缀或后缀操作符
(2)可以根据预期类型自动构造闭包。
3、并发性
(1)Akka 框架: 用于构建并发、分布式和容错的应用程序。
(2)Futures 和 Promises: 提供异步编程的抽象,简化并发任务的管理。
(3)Scala 并发集合: 提供线程安全的数据结构,方便并发编程。
4、强大的标准库
(1)集合框架(2)字符串处理:(3)IO操作
5、与 Java 互操作性
(1)无缝调用: Scala 可以直接调用 Java 代码,并且可以在 Java 中调用 Scala 代码。
(2)Java标准库: 可以使用 Java 的标准库和框架,利用其丰富的生态系统。
6、模块化和可扩展性
(1)特质(Traits): 可以混入类中,提供类似多重继承的功能,增强代码复用性。
(2)隐式转换和参数: 支持隐式转换和隐式参数,增强代码的灵活性和可扩展性。
三、Scala语言的特点
(1)优雅
(2)速度快:表达能力强,静态编译,开发速度快
(3)能融合到Hadoop生态圈:完善Hadoop生态。
总结:Scala是一门以Java虚拟机 (JVM)为运行环境并将面向对象和函数式编程的最佳特性结合在一起的静态类型编程语言,Scala比Java代码简洁明了,表达力强,开发速度快,可以与Java相互转换使用,可以为以后学习spark和Kafka打下基础。