PLT 板


LINE

看板 PLT  RSS
我发现我没头没脑的没说清楚环境就直接发问了.... 昨天适逢debug整夜後的脑袋混沌状态...^^" 不过谢谢大家的回答,我有点头绪知道自己卡住的地方了.... 在发问前我先看了这篇在LtU 论坛的发问 http://lambda-the-ultimate.org/node/2971 标题是: doing letrec with lambdas 课程上正在用scheme实作一个interpreter(mini-scheme),有environment机制 概念上是先订一组global environment 另外这个interpreter也支援high order function. 在这interpreter里面,lambda function evaluation的实作是: (eval (lambda ( arguments ) (function body) ) env ) 会被转为 (%func ( arguments ) ( function body ) env ) 因为lambda function 有打包当时环境,所以後来执行该lambda function 时, function body 会查找的便是打包的环境 (所以是static scoping?) 题目是要在这样的环境下实作 define, let, let*, letrec 这几个机制 其共通性就是在处理这些function call 的时候 要如何对应的更改其中的environment. 我想发问的是在这种语言条件的情境下,letrec的概念大概是如何? 例如 define 其实就是把global 环境多加一组binding let 就是先把 let 的东西一口气加入环境後,在用更改过的环境eval body 可是letrec 的问题如下段程式码描述: (letrec ( (f (lambda (x) ...有递回的call 到f... ) ) ) ( f 3 ) ) f 是个递回函式,call到自己 body则是使用f 当我试图要在环境中先制造一组 (f (%func ... env ) ) 的bindings 时 f 要bind 到一个lambda function 的值~其中会包一个env 而因为这个lambda function 里面会使用到 f, 所以包进去的env 里面也会需要有 f bind 一个lambda function 的值 可是这个 lambda function 也需要有个env .... (以下省略,总之无限後退) 我後来的实作方法是先在目前的environment造一组 ( f 'dontcare ) 的binding 用这个environment eval 此lambda function 後 ,此时回传一个 (%func ... ) 的值 再利用set-cdr! 把本来设为 'dontcare 的binding 改为回传的那个值 这样的确就成功实作letrec了,可是我却不之所以然.... 所以想问问有没有比较学理的描述可以说明我这样的行为。 文章一开始提到的那个发问里面 有提到说如果语言机制里面允许 "mutable references" 就可以做到我正在做的事情 可是我想这也只是工具上的不同 我会再去弄那本课本来看~先谢过大家的回答了! -- 被爱....都是毒药 爱着一个人....只会感受到付出没有回报的悲伤 被一个人爱上....却会因为不能回应而觉得有罪恶感 也许.....和被爱..都只有一种解药....那就是.... 深深爱上一个深爱你的人 --



※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 114.45.217.232







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:Soft_Job站内搜寻

TOP