CLisp 8:用LISP的基本规则实现while
2012-08-12 21:19
489 查看
要实现的while控制结构如下(用C/Java语言描述):
while (test) body;
要实现循环,要么用递归函数,要么用goto。用goto的等效实现如下:
label:
if (test)
{
body;
goto label;
}
LISP的七个基本规则中没有goto,要介绍CLisp的新操作符tagbody
tagbody将多条LISP语句组在一起,按顺序执行,例如
(tagbody
(print 'a)
(print 'b)
(print 'c))
在tagbody里面可以加标签、和go语句
(tagbody
(print 'a)
(go label_x)
(print 'b)
label_x
(print 'c))
上面语句不会打印字母B,注意标签后面不需要冒号
用tagbody实现的while语句
(tagbody
while_label
(cond (test body (go while_label)))
例如打印1~10的循环
x=0
while (x<10) {
++x;
print (x); }
可以实现为
(setq x 0)
(tagbody
while_label
(cond ((< x 10) (setq x (+ 1 x))
(print x)
(go while_label))))
最后实现while宏
(defmacro while. (test &rest body)
`(tagbody
while_label
(cond (,test ,@body (go while_label)))))
用while宏重新实现打印1~10的循环
(setq x 0)
(while. (< x 10)
(setq x (+ 1 x))
(print x))
但是,这个while宏存在陷阱,调用的代码里面不应该看到标签while_label,但确确实实能
够看到。
(setq x 0)
(while. (< x 10)
(setq x (+ 1 x))
(go while_label)
(print x))
不管怎么说,这终究是个问题。可以用gensym生成一个唯一的标识符,代替写死的
while_label。
(defmacro while. (test &rest body)
(let ((label (gensym)))
`(tagbody
,label
(cond (,test ,@body (go ,label))))))
while (test) body;
要实现循环,要么用递归函数,要么用goto。用goto的等效实现如下:
label:
if (test)
{
body;
goto label;
}
LISP的七个基本规则中没有goto,要介绍CLisp的新操作符tagbody
tagbody将多条LISP语句组在一起,按顺序执行,例如
(tagbody
(print 'a)
(print 'b)
(print 'c))
在tagbody里面可以加标签、和go语句
(tagbody
(print 'a)
(go label_x)
(print 'b)
label_x
(print 'c))
上面语句不会打印字母B,注意标签后面不需要冒号
用tagbody实现的while语句
(tagbody
while_label
(cond (test body (go while_label)))
例如打印1~10的循环
x=0
while (x<10) {
++x;
print (x); }
可以实现为
(setq x 0)
(tagbody
while_label
(cond ((< x 10) (setq x (+ 1 x))
(print x)
(go while_label))))
最后实现while宏
(defmacro while. (test &rest body)
`(tagbody
while_label
(cond (,test ,@body (go while_label)))))
用while宏重新实现打印1~10的循环
(setq x 0)
(while. (< x 10)
(setq x (+ 1 x))
(print x))
但是,这个while宏存在陷阱,调用的代码里面不应该看到标签while_label,但确确实实能
够看到。
(setq x 0)
(while. (< x 10)
(setq x (+ 1 x))
(go while_label)
(print x))
不管怎么说,这终究是个问题。可以用gensym生成一个唯一的标识符,代替写死的
while_label。
(defmacro while. (test &rest body)
(let ((label (gensym)))
`(tagbody
,label
(cond (,test ,@body (go ,label))))))
相关文章推荐
- CLisp 7:用LISP的基本规则实现if
- CLisp 10:用LISP的基本规则实现switch...case
- COM+架构的基本思想——实现IUnknown::QueryInterfacce方法时的规则
- .net实现自定义UBB代码及规则的基本实现
- 集合的基本运算: 依据集合运算规则,实现任意给定两个集合的交、并、差、笛卡儿积运算,和第一个集合的幂集,并显示运算结果。
- 面向对象地分析Linux内核设备驱动(1):——Linux内核驱动中面向对象的基本规则和实现方法
- IOS学习之——定位服务2 实现基本定位
- Javascript计算器(一)-基本功能实现
- zabbix之2安装编译/基本功能实现
- (unix网络编程)tcp回射程序一:基本实现
- 单链表的基本实现
- 自编Java版记事本(基本功能实现,界面尚可)
- Java连接数据库,实现“增、删、改、查”的基本操作
- ajax-1:基本实现原理
- 基本文件IO的实现
- JAVA API调用elasticsearch实现基本增删改查
- winform异型不规则界面设计的实现方法
- 眼见为实(1):C++基本概念在编译器中的实现
- [寒江孤叶丶的Cocos2d-x之旅_36]用LUA实现UTF8的字符串基本操作 UTF8字符串长度,UTF8字符串剪裁等
- EVM运用基本规则