• 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分支了

     

     

  • 相关阅读:
    Databend 存储架构总览
    如何使用 ELEMENTOR
    WSDM‘22推荐系统论文梳理
    【动态规划】是泰波那契数,不是斐波那契数
    DFT工程师怎样才能做到年薪50W+ ?
    分布式账本技术(Distributed Ledger Technology)和区块链(Blockchain)的简要介绍
    HALCON边缘检测
    项目问题-常见错误
    Win10 开机突然不断重复诊断和自动修复,安全模式也进不了,如何解决?(已解决)
    Android NDK篇-C++之 强制转换与智能指针
  • 原文地址:https://blog.csdn.net/libaowen609/article/details/126367736