Scala语法(三)

模式匹配

1)match

val a = 1
val b=a match {           *// a match {   }返回值赋予变量 b
case 1 => "red"
case 2 => "green"
case _ => "Not Allowed" *//其他通配符 _
or
case unexpected => unexpected +"is Not ALLOWED"
} println(b) // 输出red
for(elem <- List(9,12.3,"spark","hadoop",‘Hello)) {
    val value = elem match {
        case i :Int if(i>=0) => i +"is an int value" *// 可以添加守卫(if)
        case d:Double => d+"is a double value"
        case s:String => s+"is a str value"
        case _ => "This is an unexpected value"
}
println(value)

}

2) case类

case calss Car(brand:String,price:Int)
val BYD = new Car("BYD",89000)
val BWM = new Car("BWM",1000000)
val DABEN = new Car("BEN",1200000)
for(car <-List(BYD,BWM,DABEN)) {
    car match{
        case Car("BWD”,89000) =>println("HELLO,BYD")
        case Car("BWM",1000000) =>println("Hello,BWM")
        case Car("BEN",1200000) => println("Hello,DABEN")
}
}

Option类型

*//(引用值存在与否,不存在未None)

val books = Map("a"->1,"b"->2)
book.get("a")  *//返回Option[Int] = Some(5)
book.get("c") *//返回Option[Int] = None

函数式编程

*//(函数如变量一样有类型和值)

def counter(a:Int):Int={a+=1}   *//函数类型为: (Int)=>Int 参数只有一个时圆括号可省略`
 //函数的值: (a) => {a+=1}   只有一条语句时大括号可省略

匿名函数(Lamda表达式)

val a = (num:Int) => num*2  //将匿名函数赋值给变量a
a(3) //返回6

闭包

val addMore =(x:Int)=>x+more *//(每次函数调用都会创建新闭包,每个闭包会访问闭包创建时活跃的more变量)

占位符:

var myList = List(1,2,3,4)
myList.filter(x=x>0)   == myList.filter(_>0)
val f = (_: Int) +(_:Int)
f(5,10) = 15

遍历

1)for(elem<-myList) println(elem)

2) mylist.foreach(elem =>println(elem)) ==mylist.foreach(println) == mylist foreach println

映射遍历:

val myMap = Map("a"->1,"b"->2)
1)for((k,v)<-myMap) printf("%s,%d",k,v)
2)myMap foreach {case(k,v) =>println(k+":" +v)}

map操作

myList.map(elem=>elem+1)
myList.map(elem=>(1,elem+1)  //转换为(key,value)
flatmap(拍扁操作)// List("hadoop","hive").flatmap(s=>s.toList)   == List(h,a,d,o,o.....)

filete操作

books.filter(s =>s._2 contains 1)  // s._2代表value s._1代表key
reduce操作(归约)
myList.reduceLeft(_+_)  == ((1+2)+3)+4
myList.reduceRight(_-_) ==     1-(2-(3-4))

flod操作(折叠)

myList.flod(10)(_*_) ==1*2*3*4*10 = 240

原文地址:https://www.cnblogs.com/CYRgrowing1215/p/9547387.html

时间: 2024-10-13 00:32:11

Scala语法(三)的相关文章

scala学习三---文件里读取文本行

学习了scala的基本知识后,发现了scala是集函数式和指令式结合为一体的一种语言,代码更加简洁,但是对于用习惯了java的人来说,还真的不是一件易事~~ 今天学习scala脚本读取文本文件 列子如下: import scala.io.Source if(args.length>0){ for(line <- Source.fromFile(args(0)).getLines) print(line.length+" "+line) }else{ Console.err.

scala 语法要点

前段时间看了下scala做了下笔记,为后续看spark做点准备,笔记内容见图片,有兴趣的图片下载下去,放大看看. scala 语法要点,布布扣,bubuko.com

Python 基础语法(三)

Python 基础语法(三) --------------------------------------------接 Python 基础语法(二)-------------------------------------------- 七.面向对象编程 python支持面向对象编程:类和对象是面向对象编程的两个主要方面,类创建一个新的类型,对象是这个类的实例. 对象可以使用普通的属于对象的变量存储数据,属于对象或类的变量被称为域:对象也可以使用属于类的函数,这样的函数称为类的方法:域和方法可

Swift入门教程:基本语法(三)

打印输出 Swift提供了2个打印输出函数 println :输出内容后会自动换行 print :对比println,少了个自动换行的功能 示例 输出字符串 println("欢迎学习传智播客iOS学院Swift教程") var name = "传智播客iOS学院\n" print(name) 输出其他数据类型 var age = 7 println(age) println("我今年\(age)岁") 元组类型 什么元组类型 元组类型由 N个

scala语法解析(解码指环)

看惯了JAVA的语法,再看scala的语法,有的晦涩难懂.正好遇到一个介绍scala语法的文章,就直接截图留念.省的再临时抱佛脚了. scala语法解析(解码指环)

Scala语法学习手册

1       快速入门... 2 1.1             分号... 2 1.2             常变量声明... 2 1.2.1         val常量... 2 1.2.2         var变量... 2 1.2.3         类型推导... 3 1.2.4         函数编程风格... 3 1.3             Range. 3 1.4             定义函数... 4 1.5             while.if 4 1.6

Scala学习(三)----数组相关操作

数组相关操作 摘要: 本篇主要学习如何在Scala中操作数组.Java和C++程序员通常会选用数组或近似的结构(比如数组列表或向量)来收集一组元素.在Scala中,我们的选择更多,不过现在我们先假定不关心其他选择,而只是想马上开始用数组.本篇的要点包括: 1. 若长度固定则使用Array,若长度可能有变化则使用ArrayBuffer 2. 提供初始值时不要使用new 3. 用()来访问元素 4. 用for (elem<-arr)来遍历元素 5. 用for (elem<-arr if…)…yie

scala语法

一:常量与变量 1.常量 2.两种变量定义方式 3.注意点 变量名后加上: 类型首字母是大写 4.占位符_ 但是需要制定类型 5.scala数据类型 6.其他类型 7.懒加载lazy 定义的时候不会初始化,执行过程中才加载,使用数据 二:函数定义 1.函数格式 2. 三:默认值 1. 四:可变参数 1.使用方法* 2.

Scala第三章学习笔记

换行后的左大括号造成的问题: class FooHolder { def foo() { println("foo was called") } } Scala认为def foo()这行代码定义了一个抽象方法.这是因为它没有捕捉到后面的大括号,认定def foo()是完整的一行语句.当编译时,它认为这是一个洗呢匿名代码块,应该在类构建过程中执行. 解决办法:加一条新的编码规定,要求所有的方法定义使用"="语法. trait FooHolder2{ def foo()