dav*_*k01 5 functional-programming scala referential-transparency
阅读"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 }
}
Run Code Online (Sandbox Code Playgroud)
因此,本书中给出的论点y是不是引用透明的,因为如果我们将它替换为try块中的主体,我们得到的结果与直接运行函数时的结果不同.这对我没有任何意义,因为整个函数从一开始就是非终止的,那么说函数体中的值是不是在引用上是透明的呢?我心中的天真替代如下
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 }
}
Run Code Online (Sandbox Code Playgroud)
并且仍然以相同的异常失败.
此外,y它本身是一个非值(它不能直接被评估为一个值),那么谈论这些表达式的引用透明度有什么意义呢?我怀疑这里有什么样的手法,所以我的推理到底是不正确的?
本书中提出的观点是,如果它真的是引用透明的,那么你可以y完全删除变量并在其中替换它,try/catch并最终得到不同的语义.
因此,要点是,在例外的情况下,异常的评估点很重要.
也许你可以争辩说这两个程序在语义上并不相同,因为评估的位置在这里真正重要.如果你做了y lazy,那么结果就不会改变.