免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4720 | 回复: 1
打印 上一主题 下一主题

关于scheme的call/cc,有个问题请教 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-05-01 21:01 |只看该作者 |倒序浏览
本帖最后由 lispmm 于 2013-05-01 21:16 编辑
  1. (define self
  2.   (lambda (x) x))

  3. (define fun
  4.   (lambda (x) 2))

  5. (define a (call/cc self))

  6. (a fun)
  7. (a fun)
  8. (let ((b (call/cc self))) (b fun))
复制代码
在guile 1.8和2.0中,最后三个表达式的结果不同,
(a fun) => #<unspecified>
(a fun)=> 2
(let ((b (call/cc self))) (b fun)) => 2
不明白,恳求达人指点。

论坛徽章:
0
2 [报告]
发表于 2013-05-07 22:46 |只看该作者
看来很多材料,突然明白怎么回事了。

(define a (call/cc (lambda (x) x)))之后,a就是一个continuation,只不过还没绑定。
第一次执行(a fun),此时控制跳转到(define a (call/cc (lambda (x) x)))中的call/cc表达式中。
接下来就是fun作为call/cc表达式的返回值,而call/cc表达式的返回值被define到变量a上。
define表达式结束,无继续进行的求值。

第二次求值(a fun)时,a已经是fun,所以就是求值(fun fun)=>2

对于(let ((b (call/cc self))) (b fun))来说,
首先 b被绑定为一个continuation,然后求值(b fun)。
求值(b fun)是的控制跳转到call/cc表达式中,并将fun作为call/cc的表达式的返回值。
然后b被绑定到call/cc的返回值,及fun。
然而,到此let表达式并未结束,还要继续求值let表达式的body,也就是(b fun)。
由于b已被绑定到fun,所以let表达式的值就是(fun fun),也就是2。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP