加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

scala – 例外和参考透明度

发布时间:2020-12-16 09:55:10 所属栏目:安全 来源:网络整理
导读:阅读“ Scala中的函数式编程”,我对有关异常不是引用透明的部分感到有些困惑. 给出的例子是 def failingFn(i: Int): Int = { val y: Int = throw new Exception("fail!") try { val x = 42 + 5 x + y } catch { case e: Exception = 43 }} 因此,本书中给出的
阅读“ Scala中的函数式编程”,我对有关异常不是引用透明的部分感到有些困惑.

给出的例子是

def failingFn(i: Int): Int = {
  val y: Int = throw new Exception("fail!")
  try {
    val x = 42 + 5
    x + y
  }
  catch { case e: Exception => 43 }
}

因此,本书中给出的论点是y不是引用透明的,因为如果我们将它替换为try块中的body,我们会得到与直接运行函数不同的结果.这对我没有任何意义,因为整个函数从一开始就是非终止的,那么说函数体中的值是不是在引用上是透明的呢?我心中的天真替代如下

def failingFn(i: Int): Int = {
  val y: Int = throw new Exception("fail!")
  try {
    val x = 42 + 5
    x + ((throw new Exception("fail!")): Int)
  }
  catch { case e: Exception => 43 }
}

并且仍然以相同的异常失败.

此外,y本身是一个非值(它不能直接被评估为一个值),那么谈论这些表达式的引用透明度有什么意义呢?我怀疑这里有什么样的手法,所以我的推理到底是不正确的?

解决方法

本书中提出的观点是,如果它真的是引用透明的,那么你可以完全删除y变量并在try / catch中替换它,最后你会得到不同的语义.

因此,要点是,在例外的情况下,异常的评估点很重要.

也许你可以争辩说这两个程序在语义上并不相同,因为评估的位置在这里真正重要.如果你使y懒惰,那么结果不会改变.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读