- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有一个通用方法,比如 incx
. incx
有两个版本.一种专攻类型 a
,还有一个专门针对类型 b
.类型 b
是 a
的子类.你得到一个类型为 b
的对象,派生类型 - 但您想调用专门用于类型 a
的方法.如果还没有专门用于类型 b
的同名方法,您可以轻松地做到这一点。 ,不过唉,居然有这样的方法。
那么如何调用专用于类型 a
的方法?在这种情况下?
(defclass a () ((x :accessor x :initform 0)))
(defclass b (a) ((y :accessor y :initform 0)))
(defgeneric inc (i))
(defmethod inc ((i a)) (incf (x i)))
(defmethod inc ((i b)) (incf (y i)))
(defvar r (make-instance 'b))
* (inc r)
* (describe r)
..
Slots with :INSTANCE allocation:
X = 0
Y = 1
(inc (r a)) ; crashes and burns of course, no function r or variable a
(inc a::r) ; of course there is no such scoping operator in CL
call-next-method
函数可以从一个专门的方法中使用来获得下一个不那么专门的方法,但这不是这里想要的。
call-next-method
的内容。 ,但用于调用补充方法。我们不需要在下一个不太专业的类中调用同名的方法,而是需要调用它的补充方法,它具有不同的名称。补充方法也是专门的,但调用这个专门的版本不起作用 - 与
call-next-method
的原因大致相同。可能被包括在内。专用于父类(super class)的所需方法并不总是具有相同的名称。
(call-next-method my-complement) ; doesn't work, thinks my-complement is an arg
(defgeneric apply-velocity (particle velocity))
(defgeneric flip-spin (particle))
;;;; SIMPLE ELECTRONS
(defclass electron ()
((mass
:initform 9.11e-31
:accessor mass)
(spin
:initform -1
:accessor spin)))
(defmacro sq (x) `(* ,x ,x))
(defmethod apply-velocity ((particle electron) v)
;; stands in for a long formula/program we don't want to type again:
(setf (mass particle)
(* (mass particle) (sqrt (- 1 (sq (/ v 3e8)))))))
(defmethod flip-spin ((particle electron))
(setf (spin particle) (- (spin particle))))
;;;; STRANGE ELECTRONS
(defclass strange-electron (electron)
((hidden-state
:initform 1
:accessor hidden-state)))
(defmethod flip-spin ((particle strange-electron))
(cond
((= (hidden-state particle) 1)
(call-next-method)
;; CALL ELECTRON'S APPLY-VELOCITY HERE to update
;; the electron. But how???
)
(t nil)))
;; changing the velocity of strange electrons has linear affect!
;; it also flips the spin without reguard to the hidden state!
(defmethod apply-velocity ((particle strange-electron) v)
(setf (mass particle) (* (/ 8 10) (mass particle)))
;; CALL ELECTRON'S SPIN FLIP HERE - must be good performance,
;; as this occurs in critical loop code, i.e compiler needs to remove
;; fluff, not search inheritance lists at run time
)
最佳答案
我更喜欢这里的显式方法:
(defun actually-inc-a (value) (incf (x value)))
(defun actually-inc-b (value) (incf (y value)))
(defmethod inc ((object a)) (actually-inc-a object))
(defmethod inc ((object b)) (actually-inc-b object))
(defun apply-velocity-for-simple-electron (particle v)
(setf (mass particle) (* (mass particle) (sqrt (- 1 (sq (/ v 3e8)))))))
(defun flip-spin-for-simple-electron (particle)
(setf (spin particle) (- (spin particle))))
(defmethod apply-velocity ((particle electron) v)
(apply-velocity-for-simple-electron particle v))
(defmethod flip-spin ((particle electron))
(flip-spin-for-simple-electron particle))
(defmethod apply-velocity ((particle strange-electron) v)
(setf (mass particle) (* (/ 8 10) (mass particle)))
(flip-spin-for-simple-electron particle))
(defmethod flip-spin ((particle strange-electron))
(when (= (hidden-state particle) 1)
(call-next-method)
(apply-velocity-for-simple-electron particle #| Hu? What's the V here? |#)))
关于inheritance - CLOS:如何调用一个不太具体的方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35171694/
任何 CL'er 都可以解释一下 CLOS 中的“插槽”吗?我发现很难理解插槽名称后面的部分。那是在: (defclass foo() (data1 :initarg foo)) “initarg”和
有一个通用方法,比如 incx . incx有两个版本.一种专攻类型 a ,还有一个专门针对类型 b .类型 b是 a 的子类.你得到一个类型为 b 的对象,派生类型 - 但您想调用专门用于类型 a
在阅读 CLOS(Paul Graham 在 ANSI Common Lisp 中)时,我注意到有九个函数可以作为第二个参数提供给 defmethod:+, and, append, list, ma
当类在列表中时,我无法使用 clos 访问器函数。 假设我有 a 类: (defclass a () ((a :accessor a :initarg :a))) 我制作了 2 个实例
我对使用 CLOS 还很陌生。在这里,我写了一种使用 CLOS 定义队列的可能方法: (defclass Queue () ((queue-size :reader queue
你会如何用 Lisp 表达下面的 Java 代码? class Foo { private String s; public Foo(String s) { this.
我正在尝试创建一个类,该类可以将符号向量存储在 SBCL 的槽中。我不知道如何设置它。 到目前为止我最好的猜测是 (defclass Individual () ((discrete-decisi
我正在寻找一种以浅层方式克隆 CLOS 对象的方法,因此创建的对象将具有相同的类型,在每个插槽中具有相同的值,但是是一个新实例。我发现的最接近的是一个标准函数复制结构,它对结构执行此操作。 最佳答案
我正在学习 CLOS 中的通用函数。 由于我在教科书和网上找到的示例类型,我感到非常困惑。这些示例始终使用存在多个分派(dispatch)的事实。根据参数类型,执行不同的计算。但是,为什么示例中从未使
有没有类似CLOS的东西(Common Lisp 对象系统)用于 Clojure? 最佳答案 您是否考虑过 Clojure 的 data types (尤其是 defrecord),protocols
我正在学习构建我的 CL 程序,现在在使用大型包进行编程时无法使用 CLOS。 包.lisp (defpackage :my-project.a (:use :cl) (:export
我有以下类(class): (defclass category () ((cat-channel-name :accessor cat-channel-name :initarg :
我遇到过这样的说法,即 Common Lisp 对象系统 (CLOS) 优于传统的(基于类的)面向对象系统。 Wikipedia entry for CLOS提到了这两种方法之间的差异——主要是多重分
访问类槽时,而不是写入 (defmethod get-name ((somebody person) (slot-value somebody 'name)) 是否可以使用点符号(又名 C++),即
在 Common Lisp 中,是否有一种白话,可以像在 Java 中那样为一次性的“小型接口(interface)实现者”定义匿名类? 例如, this.addListener(new Listen
我想知道为什么 Common Lisp 中没有内置的相等运算符来比较 CLOS 对象(标准类)。例如,“equalp”可以应用于数组、结构、哈希表,但不能应用于对象。 我假设一个新的测试下降一个对象并
我有一个 CLOS 对象的插槽名称列表: (DEFCLASS TRIAL-DATA (STANDARD-OBJECT) ((A-DATUM :ACCESSOR A-DATUM :INITARG :A
我有一个 Node 类,它有一个“元素”插槽,其中包含一个包含数字和一个字母的列表,例如: '(1 2 3 b 4 5 6) (defclass node () ((element :reader
我正在尝试在 Common Lisp 中执行一个多重方法的“重载调用”。这是案例的简化摘要: (defclass foo () ((slotty :accessor slotty :initarg
我需要一些帮助来理解以下代码的执行顺序。 我创建了一个 pie 的实例,使用以下内容: (cook (make-instance 'pie)) 我知道 lisp 从最具体到最不具体的顺序执行函数。但是
我是一名优秀的程序员,十分优秀!