NullPointerException clojure println

时间:2011-11-06 20:42:46

标签: clojure nullpointerexception println

我正在学习clojure,我在这个非常丑陋,反本能,愚蠢的代码中发现了一个问题:

(ns music-tag.core
  (:import
   (java.io.File)
   (com.echonest.api.v4.EchoNestAPI)
   (com.echonest.api.v4.Track)))

(def api-key "JRZSJUMBK8VOOP0L2")

(def music (new java.io.File "/home/simo/Musica/musica_mp3/Rabiosa-Shakira.mp3"))
(def echo-nest (new com.echonest.api.v4.EchoNestAPI api-key))
(def traccia (. echo-nest uploadTrack music true))

(. traccia waitForAnalysis 30)

(do (println (. traccia getArtistName) (. traccia getTitle)))

当我运行此文件时,我得到正确的答案(打印艺术家和标题),但它会引发异常:

simo@simo:~/music-tag$ lein run
Shakira Rabiosa (Featuring Pitbull)
Exception in thread "main" java.lang.NullPointerException
    at user$eval39.invoke(NO_SOURCE_FILE:1)
    at clojure.lang.Compiler.eval(Compiler.java:6465)
    at clojure.lang.Compiler.eval(Compiler.java:6455)
    at clojure.lang.Compiler.eval(Compiler.java:6431)
    at clojure.core$eval.invoke(core.clj:2795)
    at clojure.main$eval_opt.invoke(main.clj:296)
    at clojure.main$initialize.invoke(main.clj:315)
    at clojure.main$null_opt.invoke(main.clj:348)
    at clojure.main$main.doInvoke(main.clj:426)
    at clojure.lang.RestFn.invoke(RestFn.java:421)
    at clojure.lang.Var.invoke(Var.java:405)
    at clojure.lang.AFn.applyToHelper(AFn.java:163)
    at clojure.lang.Var.applyTo(Var.java:518)
    at clojure.main.main(main.java:37)

为什么呢? 我怎么解决呢???

由于

1 个答案:

答案 0 :(得分:0)

我不确定,但我认为这只是因为没有定义主要方法。

尝试将代码从最后一个def更改为:

(defn -main[] 
  (let [traccia (. echo-nest uploadTrack music true)]
    (do
      (. traccia waitForAnalysis 30)
      (println (. traccia getArtistName) (. traccia getTitle)))))

当lein编译代码时,它需要运行顶级语句,其中包括方法调用,因为它们没有隐藏在函数中。在运行代码时,barfs会出现异常,因为它无法运行。