common-lisp - CL中的fdefiniton和函数(特殊运算符)有什么区别?

标签 common-lisp

所以我正在阅读 Quicklisp 代码,试图理解它并从中学习。 我见过这个宏:

(defmacro neuter-package (name)
      `(eval-when (:compile-toplevel :load-toplevel :execute)
         (let ((definition (fdefinition 'error-unimplemented)))
           (do-external-symbols (symbol ,(string name))
             (unless (fboundp symbol)
               (setf (fdefinition symbol) definition))))))

据我所知,fdefinition 和 function(#') 之间的唯一区别是 fdefinition 是可设置的。我对吗? 如果是,那么省略let部分并将setf更改为

不是更简单(或者可能更有效)
(setf (fdefinition symbol) #'error-unimplemented)

最佳答案

FDEFINITION 是一个函数。 FUNCTION 是一个特殊的运算符。 FDEFINITION 因此获得了一个评估的参数。

(setf (fdefinition symbol) #'error-unimplemented)

上面的意思是将全局函数定义设置为函数ERROR-UNIMPLMENTED。它也可能是具有该名称的词法绑定(bind)函数。

(flet ((error-unimplemented (...) ...))
  (neuter-package "FOO"))

上面将使用词法绑定(bind)函数。

另请注意,在某些情况下,Lisp 编译器可能会假设使用了特定的当前函数ERROR-UNIMPLMENTED。例如,用于内联或无需查找的调用。

但是代码使用FDEFINITION

(setf (fdefinition symbol) (fdefinition 'error-unimplemented))

上面将在运行时从符号中查找全局函数...

(flet ((error-unimplemented (...) ...))
  (neuter-package "FOO"))

上面不会使用词法绑定(bind)函数。

关于common-lisp - CL中的fdefiniton和函数(特殊运算符)有什么区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27217432/

相关文章:

lisp - Common Lisp 中标准对象和标准类的层次结构

stack - 如何清空列表

lisp - 函数内的 DELETE + SETF

common-lisp - 普通口齿不清 : read list into list

list - 使用 lisp 中的嵌套列表删除列表的重复元素

macros - 构建评估的评估是否等于宏观?

linux - 给BT :MAKE-THREAD a htop visible name (SBCL)

lisp - 为什么 Setq 工作但不让?

multithreading - 波尔多线程 : how to kill a thread?

lisp - 测试列表的所有元素是否彼此不同