• 2023_Spark_实验七:Scala函数式编程部分演示


    1、Scala中的函数

    在Scala中,函数是“头等公民”,就和数字一样。可以在变量中存放函数,即:将函数作为变量的值(值函数)。

    1. def myFun1(name:String):String="Hello " + name
    2. println(myFun1("Tom"))
    3. def myFun2():String = "Hello World"
    4. //值函数:将函数作为变量的值
    5. val v1 = myFun1("Tom")
    6. val v2 = myFun2()
    7. //再将v1 付给myFun1(v1)
    8. println(myFun1(v1))

    2、匿名函数

    1. //匿名函数
    2. (x:Int) => x*3
    3. //例子:(1,2,3)---》(3,6,9)
    4. Array(1,2,3).map((x:Int) => x*3)
    5. //由于map方法接收一个函数参数,我就就可以把上面的匿名函数作为参数传递给map方法

    3、带函数参数的函数,即:高阶函数

    示例1:

    (*)首先,定义一个最普通的函数

    (*)再定义一个高阶函数

    (*)分析这个高阶函数调用的过程

    1. //定义一个最普通的函数
    2. def fun1(name:String):String = "Hello "+ name
    3. import scala.math._
    4. //定义高阶函数:带有函数参数的函数
    5. def someAction(f:(Double) => Double) =f(10)
    6. //测试
    7. someAction(sqrt)

    示例2:

    1. //另外一个例子
    2. def mytest(x:Int,y:Int) :Int ={x*y + 100}
    3. //定义一个高阶函数
    4. def myFunction(f:(Int,Int) =>Int,x:Int,y:Int) = f(x,y)
    5. //测试
    6. myFunction(mytest,1,2)

    在这个例子中,首先定义了一个普通的函数mytest,然后定义了一个高阶函数myFunction;myFunction接收三个参数:第

    一个f是一个函数参数,第二个是x,第三个是y。而f是一个函数参数,本身接收两个Int的参数,返回一个Int的值。

    4、闭包

    就是函数的嵌套,即:在一个函数定义中,包含另外一个函数的定义;并且在内函数中可以访问外函数中的变量。

    测试上面的函数:

    1. def mulBy(factor:Double)=(x:Double)=>x*factor
    2. //变量
    3. val triple = mulBy(3//表示乘以3倍的操作
    4. val half = mulBy(0.5//表示除以2倍的操作
    5. //调用
    6. println(triple(10)+ " " + half(8))

    5、柯里化:Currying

    柯里化函数(Curried Function)是把具有多个参数的函数转换为一条函数链,每个节点上是单一参数。

    一个简单的例子:

    1. //柯里化
    2. //一个普通的函数
    3. def mulByOneTime(x:Int,y:Int) = x + y
    4. //柯里化函数
    5. def mulByOneTime1(x:Int) =(y:Int) =>x * y
    6. //简写的方式
    7. def mulByOneTime2(x:Int)(y:Int)= x * y
    8. //测试
    9. mulByOneTime(6,7)
    10. mulByOneTime1(6)(7)
    11. mulByOneTime2(6)(7)

    6、高阶函数示例

    示例1:

    1. //map
    2. //在列表中的每个元素上计算一个函数,并且返回一个包含相同数目元素的列表
    3. val numbers = List(1,2,3,4,5,6,7,8,9,10)
    4. numbers.map((i:Int)=>i*2)

    示例2:

    1. //foreach
    2. //foreach 和 map 相似 ,只不过它没有返回值,foreach只要是为了对参数进行作用
    3. val numbers = List(1,2,3,4,5,6,7,8,9,10)
    4. numbers.foreach((i:Int)=>i*2)

    示例3:

    1. //filter
    2. //移除任何使得传入的函数返回false的元素
    3. val numbers = List(1,2,3,4,5,6,7,8,9,10)
    4. numbers.filter((i:Int) => i%2==0)

    示例4

    1. //zip
    2. //zip把两个列表的元素合成一个由元素对组成的列表里
    3. List(1,2,3).zip(List(4,5,6,7))

    示例5:

    1. //partition
    2. //partition根据断言函数的返回值对列表进行拆分
    3. val numbers = List(1,2,3,4,5,6,7,8,9,10)
    4. numbers.partition((i:Int) =>i%2==0)

    在这个例子中,可以被2整除的被分到一个分区;不能被2整除的被分到另一个分区。

    示例6:

    1. //find
    2. //find返回集合里第一个匹配断言函数的元素
    3. val numbers = List(1,2,3,4,5,6,7,8,9,10)
    4. numbers.find(_ % 3 ==0)

    示例7:

    1. //flatten
    2. //flatten可以把嵌套的结构展开
    3. List(List(1,2,3),List(4,5,6)).flatten

    示例8:

    1. //flatMap
    2. //flatMap 是一个常用的combinator,它结合了map 和 flatten的功能
    3. val myList = List(List(1,2,3),List(4,5,6))
    4. myList.flatMap(x => x.map(_ * 2))

    在这个例子中,分为两步:

    1. 将(1,2,3)和(4,5,6)这两个集合合并成一个集合

    2. 再对每个元素乘以2

  • 相关阅读:
    VMWare workstation虚拟机 转kvm qemu 的Qcow2格式
    Springboot集成Swagger
    在Kotlin中设置User-Agent以模拟搜索引擎爬虫
    计算机毕业设计(附源码)python在线学习资源管理系统
    tf.data.Dataset多个输入无法正确解包
    解决ARouter路由There‘s no route matched!Path =[/xxxxx/xxxx]Group = [xxxxx] 跳转 提示的吐司
    springboot实现SSE之牛刀小试
    【服务器】python通过JDBC连接到位于Linux远程服务器上的Oracle数据库
    Linux系统之部署react-tetris俄罗斯方块小游戏
    深入浅出学习透析Nginx服务器的基本原理和配置指南「Https安全控制篇」
  • 原文地址:https://blog.csdn.net/pblh123/article/details/133070315