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

相关推荐
web1376560764310 小时前
Scala的宝藏库:探索常用的第三方库及其应用
开发语言·后端·scala
知初~12 小时前
Scala基础学习
开发语言·学习·scala
阿强774 天前
scala中为什么能用常量的地方就不用变量
开发语言·后端·scala
Sup星月★然13 天前
Scala 语法入门
大数据·开发语言·scala
wlyang66616 天前
5. scala高阶之traits
大数据·开发语言·scala
qwy71522925816322 天前
3-scala的类
开发语言·后端·scala
qwy7152292581631 个月前
4.scala默认参数值
开发语言·后端·scala
百流1 个月前
scala基础学习(数据类型)-哈希表
学习·scala·散列表
李匠20241 个月前
大数据学习之SCALA分布式语言三
开发语言·学习·scala
lisacumt1 个月前
【kerberos】使用keytab文件,kerberos认证工具类 scala版本
hadoop·scala