大数据Scala面试题汇总

  1. scala语言有什么特点?什么是函数式编程?有什么优点?
  • scala同时具有⾯向对象和函数式编程的多种编程范式。
  • 函数式编程是一种编程范式,主要思想就是将程序写成一系列函数嵌套的形式,让程序的条例更清晰,灵活性更强。
  1. 什么是scala中的闭包?
  • 闭包(closure /ˈkloʊʒər/)
  • 闭包就是能够读取其他函数内部变量的函数。
复制代码
 
  1. val a = 3

  2. def add(b:Int) = a + b

  3. // add就是是一个闭包

  4. 什么是scala中的纯函数?有什么好处?

  • 是什么
    • 纯函数(Pure Function /pjʊr/ /ˈfʌŋkʃn/)所有的输入通过参数传递到函数内部,所有的输出通过返回值传递到函数外部;
    • 闭包或者带有打印语句的函数为非纯函数。
  • 好处
    • 无状态,线程安全,不需要线程同步;
    • 纯函数相互调用组装起来的函数,还是纯函数;
    • 应用程序或者运行环境(Runtime)可以对纯函数的运算结果进行缓存,运算加快速度。
复制代码
 
  1. //纯函数 输入都来自参数 输出都通过返回值

  2. def f1(a:Int,b:Int) = a + b

  3. //非纯函数

  4. val x = 1

  5. // 输入变量x不是通过参数输入

  6. def f2(y:Int) = x + y

  7. // 除了返回值还包含打印语句

  8. def f3(x:Int) = {

  9. println(x)

  10. x+1

  11. }

相关推荐
MZWeiei17 小时前
Spark任务调度流程详解
大数据·分布式·spark·scala
бесплатно1 天前
Scala流程控制
开发语言·后端·scala
Bin Watson8 天前
解决 Builroot 系统编译 perl 编译报错问题
开发语言·scala·perl
什么芮.11 天前
大数据应用开发和项目实战(2)
大数据·pytorch·sql·spark·scala
不要天天开心13 天前
Spark-Streaming核心编程:有状态转化操作与DStream输出
scala
欧先生^_^14 天前
Scala语法基础
开发语言·后端·scala
不要天天开心15 天前
大数据利器:Kafka与Spark的深度探索
spark·scala
不要天天开心16 天前
Kafka与Spark-Streaming:大数据处理的黄金搭档
kafka·scala
什么芮.17 天前
spark-streaming
pytorch·sql·spark·kafka·scala
爱编程的王小美21 天前
Scala 入门指南
开发语言·后端·scala