【发布时间】:2015-06-19 04:48:56
【问题描述】:
这只是一个简化的代码,我没有设法工作。我不明白出了什么问题。
(defun enumerate-indicies (func)
(let ((index 0))
(while (< index 5)
(funcall func index)
(setq index (1+ index)))))
(defun enumerate-multiplied-indicies (func)
(enumerate-indicies #'(lambda (index)
(funcall func (* 10 index)))))
以下测试代码按预期返回10:
(defun test/enumerate-indicies ()
(let ((sum 0))
(enumerate-indicies #'(lambda (index)
(setq sum (+ sum index))))
sum))
(test/enumerate-indicies)
但以下原因在我的 Emacs 中导致 error Lisp nesting exceeds max-lisp-eval-depth:
(defun test/enumerate-multiplied-indicies ()
(let ((sum 0))
(enumerate-multiplied-indicies #'(lambda (index)
(setq sum (+ sum index))))
sum))
(test/enumerate-multiplied-indicies)
你能给我一个线索吗?这不应该是这里的递归调用,但似乎是。谢谢。
【问题讨论】:
-
启用词法绑定修复它,虽然我不知道原因。