5

我使用 IntelliJ + Cursive。

我正在对正在编写的遗传算法进行一些测试,并获得了 NPE。不清楚它来自哪里,所以我启动了我的调试器。然而,当它启动时,一个RuntimeException中断被激活,它指向这里clojure.main

(defn main
  [& args]
  (try
   (if args
     (loop [[opt arg & more :as args] args inits []]
       (if (init-dispatch opt)
         (recur more (conj inits [opt arg]))
         ((main-dispatch opt) args inits))) ; <---- Points Here
     (repl-opt nil nil))
   (finally 
     (flush))))

异常内容如下:

Exception in thread "main" java.lang.RuntimeException: Unable to resolve symbol: create in this context, compiling:(C:\Users\slomi\AppData\Local\Temp\form-init2101329611502965041.clj:4223:33

create我在它指向的代码中的任何地方都没有看到符号(这会很奇怪,因为它是clojure.main),我检查了我的整个项目,并且该符号没有在任何地方使用。我检查了异常指向的路径,发现这个烂摊子:

(.deleteOnExit (java.io.File. "C:\\Users\\slomi\\AppData\\Local\\Temp\\form-init2101329611502965041.clj")) (do (set! *warn-on-reflection* nil) (do (try (clojure.core/doto (quote ai-retry.genetic_algorithm.main) clojure.core/require clojure.core/in-ns) (catch java.lang.Exception e__11808__auto__ (clojure.core/println e__11808__auto__) (clojure.core/ns ai-retry.genetic_algorithm.main))) (try (clojure.core/require (quote clojure.tools.nrepl.server)) (catch java.lang.Throwable t__11809__auto__ (clojure.core/println "Error loading" (clojure.core/str (quote clojure.tools.nrepl.server) ":") (clojure.core/or (.getMessage t__11809__auto__) (clojure.core/type t__11809__auto__))))) (try (clojure.core/require (quote complete.core)) (catch java.lang.Throwable t__11809__auto__ (clojure.core/println "Error loading" (clojure.core/str (quote complete.core) ":") (clojure.core/or (.getMessage t__11809__auto__) (clojure.core/type t__11809__auto__))))) nil) (clojure.core/let [server__11804__auto__ (clojure.tools.nrepl.server/start-server :bind "127.0.0.1" :port 0 :ack-port 58282 :handler (clojure.tools.nrepl.server/default-handler (clojure.core/with-local-vars [wrap-init-ns__11765__auto__ (clojure.core/fn [h__11766__auto__] (clojure.core/with-local-vars [init-ns-sentinel__11767__auto__ nil] (clojure.core/fn [{:as msg__11768__auto__, :keys [session]}] (clojure.core/when-not ((clojure.core/deref session) init-ns-sentinel__11767__auto__) (clojure.core/swap! session clojure.core/assoc (var clojure.core/*ns*) (try (clojure.core/require (quote ai-retry.genetic_algorithm.main)) (clojure.core/create-ns (quote ai-retry.genetic_algorithm.main)) (catch java.lang.Throwable t__11769__auto__ (clojure.core/create-ns (quote user)))) init-ns-sentinel__11767__auto__ true)) (h__11766__auto__ msg__11768__auto__))))] (clojure.core/doto wrap-init-ns__11765__auto__ (clojure.tools.nrepl.middleware/set-descriptor! {:expects #{"eval"}, :requires #{(var clojure.tools.nrepl.middleware.session/session)}}) (clojure.core/alter-var-root (clojure.core/constantly (clojure.core/deref wrap-init-ns__11765__auto__))))))) port__11805__auto__ (:port server__11804__auto__) repl-port-file__11806__auto__ (clojure.core/apply clojure.java.io/file ["C:\\Users\\slomi\\IdeaProjects\\ai-retry" ".nrepl-port"]) legacy-repl-port__11807__auto__ (if (.exists (clojure.java.io/file "C:\\Users\\slomi\\IdeaProjects\\ai-retry\\target\\base+system+user+dev")) (clojure.java.io/file "C:\\Users\\slomi\\IdeaProjects\\ai-retry\\target\\base+system+user+dev" "repl-port"))] (clojure.core/when true (clojure.core/println "nREPL server started on port" port__11805__auto__ "on host" "127.0.0.1" (clojure.core/str "- nrepl://" "127.0.0.1" ":" port__11805__auto__))) (clojure.core/spit (clojure.core/doto repl-port-file__11806__auto__ .deleteOnExit) port__11805__auto__) (clojure.core/when legacy-repl-port__11807__auto__ (clojure.core/spit (clojure.core/doto legacy-repl-port__11807__auto__ .deleteOnExit) port__11805__auto__)) (clojure.core/deref (clojure.core/promise))))

翻遍它,任何地方都没有任何create符号。最接近的匹配是 的两个实例create-ns。我假设这是一个由 REPL 出于某种原因自动生成的文件,所以我不希望它有问题。

如果我删除该文件,则会创建一个新文件,并且在新文件中会发生同样的错误。

现在,如果我打开一个普通的非调试 REPL,我也会得到同样的错误。这完全是凭空发生的。在我第一次启动调试器之前,我已经运行了一个 REPL,而且它启动得很好。该错误仅在我启动调试器后才开始,现在它不会消失。

我尝试过lein clean,手动删除临时文件,重新启动 IntelliJ我的计算机,并确保我的代码没有一个奇怪的编译器错误,可能以一种奇怪的方式表现出来。

谁能想到这可能是什么?为什么它认为create文件中甚至不包含未解析的符号create

4

2 回答 2

5

我发现它是什么。谢谢@艾伦汤普森。

当我运行时lein run,我得到一个错误,它在我的主文件中找不到任何要运行的东西,这很奇怪,因为我的 main 有一个正确的 main 方法。我查看了我的project.clj,并意识到自从我上次启动 REPL 以来,我已经更改了主要位置,并且输入错误。

我有

:main ai-retry.genetic_algorithm.main

应该是什么时候

:main ai-retry.genetic-algorithm.main

将下划线更改为破折号可以让一切正常启动。

不过,这如何可能导致它给出的错误超出了我的范围。我将把它留在这里,以防将来有人需要处理这个问题。

于 2017-06-23T21:02:43.897 回答
2

这发生在我身上。相同的症状,相同的原因(损坏的命名空间),但表现形式略有不同:

(ns my-project.my-namespace=
                           ^-- accidental errant character

如果您遇到这种情况,请查看您的所有命名空间声明。

于 2018-05-15T16:15:29.803 回答