我有一个学校作业,必须在下周完成,但我坐在这里试图解决一个错误问题,我真的不知道为什么我得到这个?
根据我的老师,我必须得到这个:
user> (def v (safe (/ 1 0)))
user> v
ArithmeticException java.lang.ArithmeticException: Divide by zero
但是我在做这件事时得到的是:
java.io.File
user=> (def v (safe (/ 1 0)))
#'user/v
user=> v
#error {
:cause "Divide by zero"
:via
[{:type java.lang.ArithmeticException
:message "Divide by zero"
:at [clojure.lang.Numbers divide "Numbers.java" 158]}]
:trace
[[clojure.lang.Numbers divide "Numbers.java" 158]
[clojure.lang.Numbers divide "Numbers.java" 3808]
[user$fn__17 invoke "NO_SOURCE_FILE" 30]
[clojure.lang.AFn applyToHelper "AFn.java" 152]
[clojure.lang.AFn applyTo "AFn.java" 144]
[clojure.lang.Compiler$InvokeExpr eval "Compiler.java" 3623]
[clojure.lang.Compiler$DefExpr eval "Compiler.java" 439]
[clojure.lang.Compiler eval "Compiler.java" 6787]
[clojure.lang.Compiler eval "Compiler.java" 6745]
[clojure.core$eval invoke "core.clj" 3081]
[clojure.main$repl$read_eval_print__7099$fn__7102 invoke "main.clj" 240]
[clojure.main$repl$read_eval_print__7099 invoke "main.clj" 240]
[clojure.main$repl$fn__7108 invoke "main.clj" 258]
[clojure.main$repl doInvoke "main.clj" 258]
[clojure.lang.RestFn invoke "RestFn.java" 421]
[clojure.main$repl_opt invoke "main.clj" 324]
[clojure.main$main doInvoke "main.clj" 422]
[clojure.lang.RestFn invoke "RestFn.java" 397]
[clojure.lang.Var invoke "Var.java" 375]
[clojure.lang.AFn applyToHelper "AFn.java" 152]
[clojure.lang.Var applyTo "Var.java" 700]
[clojure.main main "main.java" 37]]}
答案 0 :(得分:1)
你知道了,只是错误的格式有点不同。
如果您查看:via
密钥,您会看到:type
密钥的值为java.lang.ArithmeticException
和:message
密钥'值为Divide by zero
将它们组合在一起,您将获得java.lang.ArithmeticException: Divide by zero
这可能是您如何运行REPL的问题。我从未见过这样的错误,但我通常使用leiningen命令运行REPL:lein repl