首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >既然我们已经出租了,为什么还需要letrec呢?

既然我们已经出租了,为什么还需要letrec呢?
EN

Stack Overflow用户
提问于 2021-11-16 09:24:01
回答 1查看 200关注 0票数 0

在R7RS-小部分4.2.2绑定构造中,有一个letrec示例

代码语言:javascript
复制
(letrec ((even?
          (lambda (n)
            (if (zero? n)
                #t
                (odd? (- n 1)))))
         (odd?
          (lambda (n)
            (if (zero? n)
                #f
                (even? (- n 1))))))
  (even? 88))

我不明白为什么letrec是必要的,因为我们已经在语言中使用了let。我试图将letrec替换为let,并在麻省理工学院11.2计划、球拍7.2 plt-r5rs、Chez计划9.5和Guile 3.0.1中得到了正确的值(#t)。letrec的真正用途是什么?

代码语言:javascript
复制
(let ((even?
       (lambda (n)
         (if (zero? n)
             #t
             (odd? (- n 1)))))
      (odd?
       (lambda (n)
         (if (zero? n)
             #f
             (even? (- n 1))))))
  (even? 88))
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-11-17 17:33:28

letrec不能被那样的let取代。在您的情况下,它是有效的,因为您的本地绑定正在隐藏全局绑定,然后在看起来但不是递归的调用中调用这些绑定。考虑一下

代码语言:javascript
复制
(let ((factorial
       (λ (n)
         (if (<= n 1)
        1
        (* n (factorial (- n 1)))))))
  (factorial 10))

如果您试图评估这一点,您将得到一个错误。但是,如果使用letrec,则不会:

代码语言:javascript
复制
(letrec ((factorial
          (λ (n)
            (if (<= n 1)
                1
                (* n (factorial (- n 1)))))))
  (factorial 10))

都没问题。

当然,如果您愿意通过传递函数本身作为参数来使用与U相当的东西,那么您实际上可以不使用letrec

代码语言:javascript
复制
(let ((factorial
       (λ (c n)
         (if (<= n 1)
        1
        (* n (c c (- n 1)))))))
  (factorial factorial 10))

但是,您也不需要let:几乎所有的东西都只是语法上的方便。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69986552

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档