当前位置:  开发笔记 > 编程语言 > 正文

Lisp DO变量语法推理

如何解决《LispDO变量语法推理》经验,为你挑选了1个好方法。

在Peter Seibel的Practical Common Lisp中,他给出了这个例子:

(do ((nums nil) (i 1 (1+ i)))
    ((> i 10) (nreverse nums))
  (push i nums))

我可以看到它是如何工作的,在循环中使用nums但不给它一个步骤形式.为什么要将num放在变量定义中而不是这样做:

(let (nums) (do ((i 1 (+ i 1)))
         ((> i 10) (nreverse nums))
       (push i nums)))

我确信这是一个很好的理由,但我还没有得到它.



1> Matthias Ben..:

因为它方便并且节省了缩进.此外,累加器在概念上属于循环,为什么不把它放在那里呢?

推荐阅读
可爱的天使keven_464
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有