【发布时间】:2015-04-20 13:11:33
【问题描述】:
我想创建一个宏,以便我可以在变量本身内添加变量名。我有这个Unit 记录。它的name 成员存储了将要创建的变量的名称。
即像(def a-variable (->Unit 1 1 "a-varible"))
但我不想自己传递变量名。
而且我认为宏可以派上用场。 :)
代码如下:
(defrecord Unit
[value gradient name]
Object
(toString [_]
(str name " : ")))
(defmacro create-unit1 [var-name & body]
`(def ~var-name ~(concat body (list (name var-name)))))
(defmacro create-unit2 [var-name & body]
`(def ~var-name (concat ~@body (list (name '~var-name)))))
但他们都没有给我写代码:
neurals.core> (macroexpand '(create-unit1 a (->Unit 1.0 0.0)))
(def a ((->Unit 1.0 0.0) "a"))
neurals.core> (macroexpand '(create-unit2 a (->Unit 1.0 0.0)))
(def a (clojure.core/concat
(->Unit 1.0 0.0) (clojure.core/list
(clojure.core/name (quote a)))))
neurals.core>
我想要:
(def a (->Unit 1.0 0.0 (clojure.core/name (quote a))))
在宏内执行concat的正确方法是什么?
【问题讨论】: