对下面的变量进行setf的正确方法是什么?
CG-USER(279): (defun LETTERSEARCH (string1 string2)
(let ((newString nil))
(let ((letterSearchOn nil))
(loop for i from 0 below (length string1)
always
(setf (letterSearchOn (char string1 i))
(print letterSearchOn))))))
LETTERSEARCH
CG-USER(280): (stringprod "abc" "abc")
NIL
Error: `(SETF LETTERSEARCHON)' is not fbound
[condition type: UNDEFINED-FUNCTION]
CG-USER(281): 发布于 2012-02-13 23:02:12
这应该是(setf letterSearchOn (char string1 i))。
(setf)在Common Lisp中的工作方式真的很酷;它是一个宏,但使用的宏扩展器取决于参数。例如:
(defparameter a (list 1))
(setf (car a) 2)
a ; => (2)
(setf (cdr a) (list 3))
a ; => (2 3)这看起来很奇怪吗?(car a)是一个函数...如何将其“设置”为新的值?答案是,如果(setf)的第一个参数是以car开头的列表,它将扩展为设置cons单元格的car的代码。如果第一个参数是以cdr开头的列表,它将扩展为设置cons单元格的cdr的代码。向量、哈希表等也是如此。
您甚至可以定义自己的(setf)宏,这可以扩展(setf)知道如何设置的内容的范围。在本例中,您传递的是(letterSearchOn (char string1 i)),因此它认为您希望它使用特殊的letterSearchOn宏扩展器,但还没有定义这样的setf宏扩展器。
https://stackoverflow.com/questions/9261351
复制相似问题