1

我想知道一种方法如何检查一个对象是否属于某个类,或者从它派生。例如:

(defclass a nil
  nil)

(defclass b (a)
  nil)

(defparameter *foo* (make-instance 'b))

(my-function *foo* 'a) ; => t
(my-function *foo* 'b) ; => t

或者,返回给定对象(或类)的所有基类列表的函数也将受到赞赏。

4

2 回答 2

7

使用typep

CL-USER 4 > (typep *foo* 'a)
T

CL-USER 5 > (typep *foo* 'b)
T
于 2014-07-18T11:47:48.607 回答
0

您需要使用 MOP(元对象协议)`class-direct-superclasses'

快速加载库 close-mop 并像这样使用 `class-direct-superclasses':

CL-USER> (closer-mop:class-direct-superclasses (find-class 'number))
(#<BUILT-IN-CLASS T>)
CL-USER>

如果你有一个类的实例,你可以做

CL-USER> (let ((table (make-instance 'test-table-2)))
           (class-direct-superclasses (class-of table)))
(#<STANDARD-CLASS STANDARD-OBJECT>)} 
CL-USER>

一个可能的问题(在库中记录):如果你 DEFPACKGE :USE close-mop,而不是使用 CL,:USE close-common-lisp

于 2014-07-20T12:47:36.680 回答