Spark 3000门徒第三课scala高阶函数总结

今晚听了王家林老师3000门徒spark系列课程的第三课,讲述了scala函数,下面写一下心得:

普通函数:def fun1(name:String){println(name)}

函数赋值给变量:val fun1 = functionName _

匿名函数:val fun2 = (name:String) => prinln(name)

高阶函数:def bigData(func:(String) => Unit, content: String){func(content)}

返回值是函数的函数:def func_returned(content:String) = (message:String) => println(content+ " " +message)

curring:def sum_Currying(x:Int) = (y:Int) => x+y

 

另外课后题:统计一个目录下单词出现的总次数,纯scala来做,下面是我写的代码:

import scala.io.Source
import java.io.File
import scala.collection.mutable

 

object DirectoryWordCount {

val map = mutable.Map.empty[String, Int]

def wc(file:File) {
if(file.isFile()){
val fileContent = Source.fromFile(file)
for (line <- fileContent.getLines){
line.split(" ").foreach { x =>
if(map.contains(x)) map(x) = map(x)+1
else map(x) = 1
}
}
}
else file.listFiles().foreach(wc)
}

def main(args: Array[String]) {
wc(new File("d:/lian"))
for((key,value) <- map) println(key+":"+value)

}
}

 

转载于:https://www.cnblogs.com/haitianS/p/5097547.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值