1.注释
Scala注释使用和Java完全一样。
注释是一个程序员必须要具有的良好编程习惯。
将自己的思想通过注释先整理出来,再用代码去体现。
基本语法
单行注释://
多行注释:/* */
文档注释: /** * */
2.变量和常量
基本语法
var 变量名 [: 变量类型] = 初始值
var i:Int = 10
val 常量名 [: 常量类型] = 初始值
val j:Int = 20
注意:能用常量的地方不用变量
/*变量的命名规则:1、必须是大小写字母、数字、下划线构成2、不能以数字开头3、不能是关键字
*/object Demo02Base {var i=10i=200 //i可以进行重新赋值,但是不能改变数据类型val ii=11 //常量,不能改变值}
注:类型可以省略,会自动匹配。
在scala没有基本数据类型,全是引用数据类型
在scala中,如果一个val变量指向一个容器,容器中的元素可以改变,这里指的是指向不变
规则:
(1)声明变量时,类型可以省略,编译器自动推导,即类型推导
(2)类型确定后,就不能修改,说明Scala是强数据(静态数据)类型语言。
(3)变量声明时,必须要有初始值
(4)在声明/定义一个变量时,可以使用var或者val来修饰,var修饰的变量可改变,val修饰的变量不可改。
(5)var修饰的对象引用可以改变,val修饰的对象则不可改变,但对象的状态(值)却是可以改变的。(比如:自定义对象、数组、集合等等)
3.Scala基本数据类型
Scala中一切数据都是对象,都是Any的子类
Scala中数据类型分为两大类,数值类型(AnyVal)、引用类型(AnyRef),不管是值类型还是引用类型都是对象
Scala数据类型任然遵守,低精度的值类型向高精度值类型,自动转换(隐式转换)
Scala中的String是对Java中的String增强。
Unit:对应Java中的void,用于方法返回值的位置,表示方法没有返回值。Unit是一个数据类型,只有一个对象就是()。Void不是数据类型,只是一个关键字
Null是一个类型,只有一个对象就是null。它是所有引用类型(AnyRef)的子类
Nothing是所有数据类型的子类,主要用在一个函数没有明确返回值时使用,因为这样我们可以把抛出的返回值,返回给任何的变量或者函数
AnyVal的八种数据类型:Byte,Int,Short,Long,Float,Double,Boolean,Char
package com.bigdata.scalaobject Demo02Base {def main(args: Array[String]): Unit = {val byte: Byte = 10val short: Short = 100val int = 100 //默认为Int类型val long: Long = int //将精度较小的数据类型可以直接转换为精度较大的println(long)val float: Float = 1.23F //必须加Fval double: Double = 1.23 //默认为Double类型val char='a'println(char.toInt) //将char类型转换为Int型val boolean1:Boolean=true}}
注:scala严格区分单双引号,Char的精度小于Int类型
类型转换
基本说明
(1)自动提升原则:有多种类型的数据混合运算时,系统首先自动将所有数据转换成精度大的那种数据类型,然后再进行计算。
(2)把精度大的数值类型赋值给精度小的数值类型时,就会报错,反之就会进行自动类型转换。
(3)(byte,short)和char之间不会相互自动转换。
(4)byte,short,char他们三者可以计算,在计算时首先转换为int类型。
(5)boolean无法和其他类型转化
强制类型转换直接使用.to数据类型方式,如 long.toInt
字符串类型
scala中的字符串类型来源于java中,但是做了加强和改进
package com.bigdata.scalaobject Demo02Base {def main(args: Array[String]): Unit = {//字符串类型转换val s1:String="123"println(s1.toInt) //toInt转换类型这类操作是Scala独有的,实际上是通过隐式转换加上去的println(s1.toDouble) // 隐式转换 就是动态给对象增加方法println(s1.toFloat)//字符串常见操作val s2:String="123,ffsdas,ddwfe"println(s2.toLowerCase())println(s2.toUpperCase()) //转大小写println(s2.substring(3,7)) //按照指定位置截取// Array[String] : 表示Scala中的字符串数组 相当于Java中的 String [] splitsval strings:Array[String] = s2.split(",")println(strings(1)) //java中通过[]传入下标,scala中通过()传如下标for (elem <- strings) { //增强for循环println(elem)}//String类型在Scala中比较常用的特有的方法strings.foreach(println) //以函数思想打印println(s2.head) //取头println(s2.tail) //取尾println(s2.take(3)) //取前三个println(s2.length)println(s2.size) //长度,大小println(s2.sorted) //排序println(s2.isEmpty) //判断是否为空}
}
格式化
package com.bigdata.scalaobject Demo02Base {def main(args: Array[String]): Unit = {// 格式化字符串:需要将字符串按照固定的格式进行输出// 例如:9 9 乘法表中每一个表达式都是,数 * 数 = 数 这样的格式printf("%d * %d = %d\n", 9, 9, 81) // 9 * 9 = 81 类似c语言// 还可以通过引用变量的方式进行传值val num01: Int = 9val num02: Int = 9val num03: Int = 81val _num04: Int = 81println(s"$num01 * $num02 = $num03")println(s"$num01 * $num02 = ${_num04}") // 如果需要引用的变量名以下划线开头,则需要用花括号括起来// 如果字符串需要换行,例如写SQL的时候,则可以使用""""""val sqlStr: String = "select clazz,count(*) as cnt from student group by clazz"val sqlStr2: String ="""|select clazz| ,count(*) as cnt|from student|group by clazz|""".stripMargin // 适合写SQLprintln(sqlStr)println(sqlStr2)}}
4.Scala运算符
算数运算符
注:在除运算中,如果俩个数据类型均为整数类型,则返回的是整数类型
关系运算符
注:在判断字符串时,是按照一个一个字符进行比较的
在Scala中==更加类似于Java中的equals,比较的是值,eq比较的是地址值,类似于java中的==
位运算符
& | ! >> << ~
逻辑运算符