且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

每天学一点Scala之 匿名函数

更新时间:2021-07-03 09:33:43

1、  定义

    如果一个函数没有名字的话,就是匿名函数了。只使用一次,并没有多次调用

2、  匿名函数的使用场景


    1. 将匿名函数,直接赋值给变量

    2. 将匿名函数,作为函数的参数进行使用

3、  匿名函数的几种表现形式?或者呈现形式


    1. 没有参数输入,没有返回值的匿名函数

    2. 有参数输入,没有返回值的匿名函数

    3. 有参数输入,有返回值的匿名函数

4、  匿名函数的语法规则,有两种形式吧:[一种有输入参数,一种没有输入参数]


    1. (参数名:参数类型) => 函数体

    2. 函数体

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
package com.xej.learning.nimingFunction
 
object AnonymousFunction {
   def main(args: Array[String]): Unit = {
      //对于有参数输入的匿名函数,调用时,同样要用参数输入哦
      kafkaName("apache kafka")
      println("--->:\t" + flumeName("apache flume"))
      sparkName
 
      //匿名函数的使用场景--1,作为参数,传入给高阶函数
      //下面,map,foreach里,就是匿名函数
      Array(3,2,1,5).map{(x: Int) => x + 2}.foreach(x => print(x + " "))
 
      println("\n----------------------------------------------------")
 
      Array(3,2,1,5).map{_ 1}.foreach(x => print(x + " "))
   }
 
   //匿名函数的使用场景--2,直接赋值给变量
   //参数:有参数输入,函数体:无返回值,形式的匿名函数//函数体里,可能有很多条语句哦,
   //只是最终结果,是有返回值的
   val kafkaName = (name: String) => println("--kafka-->" + name)
 
   //参数:有参数输入,函数体:有返回值,形式的匿名函数
   val flumeName = (name: String) ="--flume-->" + name
 
   //参数:无参数输入,函数体:无返回值,形式的匿名函数
   val sparkName = println("----this is spark------")
}


spark源码,marathon源码中,都大量使用了匿名函数

下面是marathon源码中的样例

每天学一点Scala之 匿名函数




















本文转自故新51CTO博客,原文链接:http://blog.51cto.com/xingej/1962419 ,如需转载请自行联系原作者