java - 从 Java 调用 Clojure : java. lang.NumberFormatException: null

标签 java clojure

尝试使用描述的方法 here我最终得到了以下简化的、缩小范围的代码,该代码仍然显示出异常:

import clojure.lang.RT;

public class FooMain {

    public static void main(String [] args) {
        RT.var("clojure.core", "read-string").invoke("(+ 1 2)"); // line-6
    }
}

运行时失败,我在帖子末尾附加了跟踪。我已经用 Clojure 1.4 或 1.5 Ivy deps 尝试过:

<dependency org="org.clojure" name="clojure" rev="1.4.0"/> 

或者:

<dependency org="org.clojure" name="clojure" rev="1.5.1"/>

跟踪

 run:
 [echo] ant.java.version=1.7
 [echo] running the app with classpath = /home/mperdikeas/esavo-reg/playground/calling-clojure-from-Java/lib-ivy/clojure-1.4.0-javadoc.jar:/home/mperdikeas/esavo-reg/playground/calling-clojure-from-Java/lib-ivy/clojure-1.4.0-sources.jar:/home/mperdikeas/esavo-reg/playground/calling-clojure-from-Java/lib-ivy/clojure-1.4.0.jar:/home/mperdikeas/esavo-reg/playground/calling-clojure-from-Java/dist/foo.jar
 [java] java.lang.ExceptionInInitializerError
 [java]     at org.apache.tools.ant.taskdefs.ExecuteJava.execute(ExecuteJava.java:194)
 [java]     at org.apache.tools.ant.taskdefs.Java.run(Java.java:771)
 [java]     at org.apache.tools.ant.taskdefs.Java.executeJava(Java.java:221)
 [java]     at org.apache.tools.ant.taskdefs.Java.executeJava(Java.java:135)
 [java]     at org.apache.tools.ant.taskdefs.Java.execute(Java.java:108)
 [java]     at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
 [java]     at sun.reflect.GeneratedMethodAccessor4.invoke(Unknown Source)
 [java]     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 [java]     at java.lang.reflect.Method.invoke(Method.java:601)
 [java]     at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
 [java]     at org.apache.tools.ant.Task.perform(Task.java:348)
 [java]     at org.apache.tools.ant.taskdefs.Sequential.execute(Sequential.java:68)
 [java]     at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
 [java]     at sun.reflect.GeneratedMethodAccessor4.invoke(Unknown Source)
 [java]     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 [java]     at java.lang.reflect.Method.invoke(Method.java:601)
 [java]     at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
 [java]     at org.apache.tools.ant.Task.perform(Task.java:348)
 [java]     at org.apache.tools.ant.taskdefs.MacroInstance.execute(MacroInstance.java:398)
 [java]     at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
 [java]     at sun.reflect.GeneratedMethodAccessor4.invoke(Unknown Source)
 [java]     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 [java]     at java.lang.reflect.Method.invoke(Method.java:601)
 [java]     at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
 [java]     at org.apache.tools.ant.Task.perform(Task.java:348)
 [java]     at org.apache.tools.ant.Target.execute(Target.java:390)
 [java]     at org.apache.tools.ant.Target.performTasks(Target.java:411)
 [java]     at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1399)
 [java]     at org.apache.tools.ant.Project.executeTarget(Project.java:1368)
 [java]     at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41)
 [java]     at org.apache.tools.ant.Project.executeTargets(Project.java:1251)
 [java]     at org.apache.tools.ant.Main.runBuild(Main.java:809)
 [java]     at org.apache.tools.ant.Main.startAnt(Main.java:217)
 [java]     at org.apache.tools.ant.launch.Launcher.run(Launcher.java:280)
 [java]     at org.apache.tools.ant.launch.Launcher.main(Launcher.java:109)
 [java] Caused by: java.lang.ExceptionInInitializerError
 [java]     at java.lang.Class.forName0(Native Method)
 [java]     at java.lang.Class.forName(Class.java:266)
 [java]     at clojure.lang.RT.loadClassForName(RT.java:2056)
 [java]     at clojure.lang.RT.load(RT.java:419)
 [java]     at clojure.lang.RT.load(RT.java:400)
 [java]     at clojure.lang.RT.doInit(RT.java:436)
 [java]     at clojure.lang.RT.<clinit>(RT.java:318)
 [java]     at FooMain.main(FooMain.java:6)
 [java]     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 [java]     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
 [java]     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 [java]     at java.lang.reflect.Method.invoke(Method.java:601)
 [java]     at org.apache.tools.ant.taskdefs.ExecuteJava.run(ExecuteJava.java:217)
 [java]     at org.apache.tools.ant.taskdefs.ExecuteJava.execute(ExecuteJava.java:152)
 [java]     ... 34 more
 [java] Caused by: java.lang.NumberFormatException: null
 [java]     at java.lang.Integer.parseInt(Integer.java:454)
 [java]     at java.lang.Integer.valueOf(Integer.java:582)
 [java]     at clojure.core$fn__6145.invoke(core.clj:6247)
 [java]     at clojure.core__init.load(Unknown Source)
 [java]     at clojure.core__init.<clinit>(Unknown Source)
 [java]     ... 48 more
 [java] Java Result: -1

最佳答案

您看到的异常是在 Clojure 运行时尝试加载 clojure.core 命名空间时引发的,然后再执行任何代码。具体来说,尝试从类路径上的 clojure/version.properties 资源解析版本号时似乎会引发异常。

  • 确保该资源确实存在。
  • 确保可以从您使用的类加载器访问该资源。

关于java - 从 Java 调用 Clojure : java. lang.NumberFormatException: null,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17349151/

相关文章:

mysql - 使用 clojure.java.jdbc 从 MySQL 流式传输

clojure - MiniKanren 有 "not"运算符吗?

string - 为什么split和join在clojure.string中的参数位置混合了?

garbage-collection - Clojure 闭包和 GC

clojure - loop-recur 怎么可能抛出 StackOverflowError?

java - 它是方法还是构造函数?

java - 添加 Recyclerview 的 itemview 总计 "views"的最佳实践是什么?

java - Observer 接口(interface)方法中 update() 中第二个参数的意义是什么

java - 为什么我的 LibGdx 游戏玩了几分钟后就黑了?

java - Repast - 将模型打包并分发为 jar,无需 GUI 和源代码