scala入门篇之-简介

近期学习到Spark首先花一下午的时间学习一下与之紧密结合的scala脚本语言:
首先我们的安装一个运行环境
1.根据你选择的scala版本来验证你的JDK版本是否合格,怎么选择,如何考虑,本文不作概述。
在这里插入图片描述
2.到官网下载合适的scala,进行安装:
展示在windows上的安装成果:
在这里插入图片描述
3.安装好scala后进行一些基础操作。练习一下。
Scala与Java没有什么太大的区别,最大的区别大概就是Scala可以不写分号;但此处需注意一点:如果是在命令行编程Scala以行为单位,所以必须在每个语句结束时加上分号以区分同一行的其他语句。

在这里插入图片描述
在这里插入图片描述

object WordCount{
	def main(args:Array[String]){
		println("hehhehehehh")
	}
}

基本语法:
1.区分大小写:Scala是大小写敏感的,这意味着标识Hello和hello在Scala中会有不同的含义。
2.类名-对于所有的雷明的第一个字母要大写
如果需要多个单词来构成一个类的名称,每个单词的第一个字母要大写。
3.方法名称:所有的方法名称的第一个字母小写
如果若干单词被用于构成方法的名称,则每个单词的第一个字母应大写。
4.程序文件名:程序文件的名称应该与对象名称完全匹配,新版本可以不匹配,但保持良好的编程习惯是必要的!
5.标识符
Scala 可以使用两种形式的标志符,字符数字和符号。
字符数字使用字母或是下划线开头,后面可以接字母或是数字,符号$在 Scala 中也看作为字母。然而以$开头的标识符为保留的 Scala 编译器产生的标志符使用,应用程序应该避免使用$开始的标识符,以免造成冲突。
Scala 的命名规则采用和 Java 类似的 camel 命名规则,首字符小写,比如 toString。类名的首字符还是使用大写。此外也应该避免使用以下划线结尾的标志符以避免冲突。符号标志符包含一个或多个符号,如+,:,? 等。
Scala 内部实现时会使用转义的标志符,比如:-> 使$colon$minus$greater 来表示这个符号。因此如果你需要在 Java 代码中访问:->方法,你需要使用 Scala 的内部名称 $colon$minus$greater。
混合标志符由字符数字标志符后面跟着一个或多个符号组成,比如 unary_+ 为 Scala 对+方法的内部实现时的名称。字面量标志符为使用"定义的字符串,比如 x yield
你可以在"之间使用任何有效的 Scala 标志符,Scala 将它们解释为一个 Scala 标志符,一个典型的使用为 Thread 的 yield 方法, 在 Scala 中你不能使用 Thread.yield()是因为 yield 为 Scala 中的关键字, 你必须使用 Thread.yield()来使用这个方法。
空行和空格
一行中只有空格或者带有注释,Scala 会认为其是空行,会忽略它。标记可以被空格或者注释来分割。
换行符
Scala是面向行的语言,语句可以用分号(;)结束或换行符。Scala 程序里,语句末尾的分号通常是可选的。如果你愿意可以输入一个,但若一行里仅 有一个语句也可不写。另一方面,如果一行里写多个语句那么分号是需要的。例如
val s = “菜鸟教程”; println(s)
Scala 包
定义包
Scala 使用 package 关键字定义包,在Scala将代码定义到某个包中有两种方式:
第一种方法和 Java 一样,在文件的头定义包名,这种方法就后续所有代码都放在该包中。 比如:
package com.runoob
class HelloWorld
第二种方法有些类似 C#,如:
package com.runoob {
class HelloWorld
}
第二种方法,可以在一个文件中定义多个包。
引用
Scala 使用 import 关键字引用包。
import java.awt.Color // 引入Color
import java.awt._ // 引入包内所有成员
def handler(evt: event.ActionEvent) { // java.awt.event.ActionEvent
… // 因为引入了java.awt,所以可以省去前面的部分
}
import语句可以出现在任何地方,而不是只能在文件顶部。import的效果从开始延伸到语句块的结束。这可以大幅减少名称冲突的可能性。
如果想要引入包中的几个成员,可以使用selector(选取器)
import java.awt.{Color, Font}
// 重命名成员
import java.util.{HashMap => JavaHashMap}
// 隐藏成员
import java.util.{HashMap => , } // 引入了util包的所有成员,但是HashMap被隐藏了
注意:默认情况下,Scala 总会引入 java.lang.
、 scala.
和 Predef._,这里也能解释,为什么以scala开头的包,在使用时都是省去scala.的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值