• Scala函数式编程


    一、函数式编程定义:

    Scala是一门既面向对象,又面向过程的语言。在Scala中,函数与类、对象地位是一样,所以说scala的面向过程其实就重在针对函数的编程 了,所以称之为函数式编程

    • 在Scala中定义函数需要使用 def 关键字,函数包括函数名、参数、函数体
    • Scala要求必须给出函数所有参数的类型,但是函数返回值的类型不是必须的,因为Scala可以自己根据函 数体中的表达式推断出返回值类型,
    • 函数中最后一行代码的返回值就是整个函数的返回值,不需要使用return

    二、函数赋值给变量

    函数,可以独立定义,独立存在,而且可以直接将函数作为值赋值给变量。

    Scala的语法规定,将函数赋值给变量时,必须在函数后面加上空格和下划线

     三、匿名函数和高阶函数

    • 在函数中也可以不用命令,这种函数称为匿名函数,可以将匿名函数直接赋值给某个变量
    • 在接收其它函数作为当前函数的参数,当前这个函数也被称为高阶函数

     其中(String) =>Unit 表示这个函数接收一个字符串,没有返回值

    四、常见的高阶函数

    map:对传入的每个元素都进行处理,返回一个元素

     flatMap:对传入的每个元素都进行处理,返回一个或者多个元素

     foreach:对传入的每个元素都进行处理,但是没有返回值

     

     filter:对传入的每个元素都进行条件判断,如果返回true,则保留该元素,否则过滤掉该元素

     

     reduceLeft:从左侧元素开始,进行reduce操作

     

     五、其它高级特性

      5.1 option与模式匹配

    Option有两种值,一个是Some,表示有值,一个None ,表示没有值

     5.2 对变量的值进行模式匹配

    match case语法格式:变量 match { case 值 => 代码 } 如果值为下划线,则代表了不满足以上所有情况下的默认处理,match case中,只要一个case分支满足并处理了,就不会继续判断下一个case分支了

     

     

  • 相关阅读:
    安全漏洞-linux漏洞修复命令
    Linux删除Mysql
    猫头虎分享已解决Bug || SyntaxError: Unexpected token < in JSON at position 0
    力扣题解22-25
    JavaSE之多线程高级(死锁、线程等待和唤醒)
    [东华杯2021] ezgadget
    算法金 | 选择最佳机器学习模型的 10 步指南
    XMLHttpRequest介绍
    SpringMVC
    debian设置允许ssh连接
  • 原文地址:https://blog.csdn.net/libaowen609/article/details/126367736