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

     

     

  • 相关阅读:
    【攻破css系列——第四天】元素显示模式
    并发编程(概念简述)
    .net 杂谈之二
    string类详解
    ElasticSearch入门之es简易版可视化界面, elasticsearch-head安装 06
    【LangChain系列 9】Prompt模版——MessagePromptTemplate
    CSS文本超出显示小数点
    Vulnhub:Os-Bytesec靶机渗透
    MetaQ(RocketMQ)
    【JavaScript】网络请求
  • 原文地址:https://blog.csdn.net/libaowen609/article/details/126367736