Scala基础篇(持续更新中...)
数据类型
下表中列出的数据类型都是对象,可以直接对它们调用方法。
数据类型描述Byte8位有符号补码整数。数值区间为 -128 到 127Short16位有符号补码整数。数值区间为 -32768 到 32767Int32位有符号补码整数。数值区间为 -2147483648 到 2147483647Long64位有符号补码整数。数值区间为 -9223372036854775808 到 9223372036854775807Float32 位, IEEE 754 标准的单精度浮点数Double64 位 IEEE 754 标准的双精度浮点数Char16位无符号Unicode字符, 区间值为 U+0000 到 U+FFFFString字符序列Booleantrue或falseUnit表示无值,和其他语言中void等同。用作不返回任何结果的方法的结果类型。Unit只有一个实例值,写成()。Nullnull 或空引用NothingNothing类型在Scala的类层级的最底端;它是任何其他类型的子类型。AnyAny是所有其他类的超类AnyRefAnyRef类是Scala里所有引用类(reference class)的基类表示Long类型,在数字后面添加L或者l作为后缀;浮点数后面有f或者F后缀时,表示Float类型,否则就是Double
变量
用关键词“var”声明变量,关键词"val"声明常量。- var myName : String = "gyt"
- val myAge : Int = 21
复制代码 scala中不一定要指明数据类型,其数据类型通过变量或常量的初始值推断出来的,因此,在没有指明数据类型的情况下,必须要给出初始值。
访问修饰符
用private关键词修饰,只能被当前类以及当前类的内部类访问到,外层类访问不到。- class Outer{
- class Inner{
- private def f(){
- println("f")
- }
- class InnerMost{
- f() // 正确
- }
- }
- (new Inner).f() //错误
- }
复制代码 用protected关键词修饰,只能被当前类的子类访问。- package p {
- class Super {
- protected def f() {println("f")}
- }
- class Sub extends Super {
- f()
- }
- class Other {
- (new Super).f() //错误
- }
- }
复制代码 没有指定任何修饰符,默认为public,在任何地方都可以被访问。
条件和循环
以下是IF...ELSE语句实例。- object Test {
- def main(args: Array[String]) {
- var x = 30;
- if( x == 10 ){
- println("X 的值为 10");
- }else if( x == 20 ){
- println("X 的值为 20");
- }else if( x == 30 ){
- println("X 的值为 30");
- }else{
- println("无法判断 X 的值");
- }
- }
- }
复制代码 以下是一个使用了 i to j 语法(包含 j)的实例,箭头 "scala.Int" case _ => "many" }}[/code]实例中第一个 case 对应整型数值 1,第二个 case 对应字符串值 two,第三个 case 对应类型模式,用于判断传入的值是否为整型,相比使用isInstanceOf来判断类型,使用模式匹配更好。第四个 case 表示默认的全匹配备选项,即没有找到其他匹配时的匹配项,类似 switch 中的 default。- object Test {
- def main(args: Array[String]) {
- var a = 0;
- // for 循环
- for( a <- 1 to 10){
- println( "Value of a: " + a );
- }
- }
- }
复制代码 使用了case关键字的类定义就是样例类(case classes),样例类是种特殊的类,经过优化以用于模式匹配。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |