第3课:Scala函数式编程彻底精通及spark源码阅读

Scala最迷人的方式是函数式编程

Spark中的多数计算都是用函数式编程的,处理数据的时候都是针对集合的,一般都会作用的集合之上。

高阶函数,是scala和java最大不同点,最大价值

今天讲每一个例子没一点,都必须掌握,开启全新的编程人生

 函数和变量都一样的,函数是独立使用,独立存在

 fun1_v =fun1 _  必须空格加下划线

Fun2 指向匿名函数 =>指向函数体


高阶函数是函数的参数是函数,这样的功能是非常的强大的

闭包在spark里面到处可见,下面spark就是闭包的例子


 

 

Reduceleft必须掌握


今天的作业是统计一个文件夹下面所有文件中所有单词出现的总次数(目前只实现了单个字符,对于多个字符后续还需要优化)

var dir =   newFile("E:\\study\\spark-1.6.0\\spark-1.6.0\\data\\mllib\\als")
var num:Int = 0
var keyword="8"
subdirs(dir)                                                 
 def subdirs(dir: File): Iterator[File] = {
        val irectory =dir.listFiles.filter(_.isDirectory)
        val files = dir.listFiles.toIterator
          for (file <- files)
          {
                    vallines = scala.io.Source.fromFile(file).getLines().toArray
                         for (line <- lines)
                {
                           var length = line.split(keyword).length
                           num = num +length-1
                }
          }
        files ++irectory.toIterator.flatMap(subdirs _)
       
    }
         
println("num:" + num)
  }
 
}





 


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
函数式编程(FP)是一种软件开发风格,它注重不依赖于编程状态的函数函数式代码易于测试和复用,容易实现并发,且不容易受到bug的攻击。Scala是一种能很好支持函数式编程的新兴JVM语言。《Scala函数式编程》是针对希望学习FP并将它应用于日常编码中的程序员而写的,内容包括:函数式编程的概念;函数式编程相关的各种“为什么”和“怎么做”;如何编写多核程序;练习和检测。 从OOP到FP,思路的转化 我是使用scala做完一个项目之后,开始阅读本书。 介绍下背景: 1 程序员 2 前C程序员,linux平台,没有很深的java背景 3 用scala做过一个2年期的项目 在使用scala的过程中,碰到的问题主要体现在: 1 scala的很多语法糖不理解,不知道为啥要这么写,有种为了这么写的简洁而这么写的感觉 2 scala很多库在设计的时候,不理解原因,包括Option,Collection的很多看似有冗余的地方 3 很多scala的默认写法,不理解 4 多态的具体化,尤其是协变的意义所在 5 各种重载的符号使用 之前读过 programming in scala,对语言的整体还停留在: 1 scala用起来比java更灵活 2 强大的collection,可以更加方便的处理collection类的数据 3 不同于java的并行处理方法,有点像c的逻辑思路 4 开发成本比java小,但是语言学习成本比java高很多 正在阅读这本书的过程中,只能一点一点说。 第一部分快要读完了,习题也快要做完了。 1 第一部分主要着墨点正是回答我上述问题的1,2,3的。很大篇幅都放在,使用scala实现scala默认库文件的API中,通过对简单的函数式编程逻辑的介绍和实践,主要是实践,建立起来一个比较明晰的scala思维模式,或者叫函数式编程的思维模式。 2 无副作用的函数式编程,同时也解释了为什么在scala中,val和var的区分为什么那么重要。 3 在做习题的过程中,尤其是在做类型推导的过程中,对原来oop,命令式编程向函数式编程转变有很大作用;而且简洁的语法,确实让人有享受编程的感觉。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值