gpt4 book ai didi

common-lisp - 编程函数定义 : How to get rid of "eval" here?

转载 作者:行者123 更新时间:2023-12-04 02:40:59 28 4
gpt4 key购买 nike

我有一组名为“ip”、“date”、“url”等的函数。

有了这些,我想生成另一组函数“ip-is”、“date-is”等。

我终于有了以下解决方案,效果很好,但是使用了“eval”。

(loop for name in '(ip date url code bytes referer user-agent) do
(let ((c-name (intern (concatenate 'string (symbol-name name) "-IS"))))
(eval `(defun ,c-name (c)
#'(lambda (l) (equal (,name l) c))))))

有人可以帮助我,如何摆脱“邪恶的评估”?将函数名称作为列表提供对我的程序至关重要。所以调用一些宏
   (define-predicate ip)
(define-predicate date)
(define-predicate url)

等等。

不适合我的需要。我对“eval”没有真正的问题,但我经常阅读,该 eval 被认为是糟糕的风格,应该尽可能避免。

提前致谢!

最佳答案

你应该在这里使用一个宏。宏在编译(或加载)期间进行评估,可用于以编程方式生成函数定义。你的代码可以写成这样:

(defmacro define-predicates (&rest names)
`(progn
,@(loop
for name in names
collect (let ((c-sym (gensym))
(l-sym (gensym)))
`(defun ,(intern (concatenate 'string (symbol-name name) "-IS")) (,c-sym)
#'(lambda (,l-sym) (equal (,name ,l-sym) ,c-sym)))))))


(define-predicates ip date url)

请注意,符号是使用 GENSYM 生成的在函数中。在这种特殊情况下,这不是绝对必要的,但我通常更喜欢这样做,以便在以后重构代码时不会有任何泄漏。

关于common-lisp - 编程函数定义 : How to get rid of "eval" here?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14798920/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com