我正在为我的学习创建一个使用Common Lisp的专家系统。 有一个全局变量: BF - >事实基础。
我这样初始化:
(defvar *BF* NIL)
我的“main函数”调用函数“initialize”,它使用大数据设置全局变量。
(defun initialize ()
(setf *BF*
'(
(metric (
(CPU-utilization NIL)
(RPI NIL)
(ART NIL)
(concurent-invocation NIL)
(stall-count NIL)
(GC-bytes-in-use NIL)
(available-thread NIL)
(available-connection NIL)
(instance-count NIL)
))
(problem (
(livelock T)
(memory-leaks T)
(code-inefficient T)
(overload T)
(under-allocation T)
(internal-chokepoint T)
(thread-leaks T)
(blocking-deadlock T)
(unending-retries T)
(overuse-external-system T)
(pig-in-a-python T)
(too-many-layers T)
(backend-bottleneck T)
(frequent-GC-resource-leaks T)
(slow-backend T)
(suddenly-slow-backend T)
(nonblocking-deadlock T)
(thread-leaks T)
))
(category (
(sudden T)
(consistent T)
(periodic T)
(progressive T)
))
)
)
)
在第一次使用此功能时,当我打印 BF 时,没关系。 然后我调用一个函数来修改 BF :
(defun apply-rule (type name value)
; Get conclusion list for this rule
(let ((conclusion (get-conclusion name value)))
(if (null conclusion)
(if (not (equal 3 value))
(return-from appliquer-regle NIL)
(return-from appliquer-regle 'T)
)
)
; Iterate on all problems in *BF*
(dolist (e (cadr (assoc 'problem *BF*)))
; If the problem is not in conclusion list, set it value to false
(if (and (member (car e) conclusion) (equal (cadr e) 'T))
()
(setf (cadr e) NIL)
)
)
(return-from apply-rule 'T)
)
(return-from apply-rule NIL)
)
此功能有效。 但是,当我想再次使用“初始化”功能时,它不起作用。当我打印 BF 时,它包含旧值... 如何重新初始化我的全局变量?
对不起我的英文,我是法国人^
答案 0 :(得分:2)
您正在修改文字数据。最好避免它,因为它的效果在可移植代码中是不确定的。想象一下通过共享文字列表来节省空间的编译器。
确保您的变量*BF*
有新分配的数据。每次初始化变量时,请使用COPY-TREE复制列表。