大数据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. }

相关推荐
geilip2 天前
知识体系_scala_利用scala和spark构建数据应用
开发语言·spark·scala
Hello.Reader2 天前
Flink 高级配置发行版剖析、Scala 版本、Table 依赖与 Hadoop 集成实战
hadoop·flink·scala
IvanCodes6 天前
八、Scala 集合与函数式编程
大数据·开发语言·scala
卓码软件测评7 天前
第三方软件测试公司:【Gatling基于Scala的开源高性能负载测试工具】
测试工具·开源·scala·压力测试·可用性测试·第三方软件测试
南棱笑笑生8 天前
20250931在RK3399的Buildroot【linux-6.1】下关闭camera_engine_rkisp
开发语言·后端·scala·rockchip
今天没有盐10 天前
内建控制-循环语句while
scala
昕昕恋恋11 天前
定向和访问成员变量
scala
IvanCodes13 天前
七、Scala 包、样例类与样例对象
大数据·开发语言·scala
浩浩kids13 天前
Scala • basis
java·开发语言·scala
Java水解21 天前
Scala深入面向对象:类、对象与伴生关系
后端·scala