每天学一点Scala之 匿名函数
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了每天学一点Scala之 匿名函数相关的知识,希望对你有一定的参考价值。
1、 定义
如果一个函数没有名字的话,就是匿名函数了。只使用一次,并没有多次调用
2、 匿名函数的使用场景
将匿名函数,直接赋值给变量
将匿名函数,作为函数的参数进行使用
3、 匿名函数的几种表现形式?或者呈现形式
没有参数输入,没有返回值的匿名函数
有参数输入,没有返回值的匿名函数
有参数输入,有返回值的匿名函数
4、 匿名函数的语法规则,有两种形式吧:[一种有输入参数,一种没有输入参数]
(参数名:参数类型) => 函数体
函数体
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源码中的样例
本文出自 “XEJ分布式工作室” 博客,请务必保留此出处http://xingej.blog.51cto.com/7912529/1962419
以上是关于每天学一点Scala之 匿名函数的主要内容,如果未能解决你的问题,请参考以下文章