Java通过JNI调用时抛出Null异常,但在从Java程序调用时有效

时间:2013-02-07 12:27:05

标签: java java-native-interface

我正在使用JNI从外部系统调用.jar库中的Java方法。我的问题是,当我编写使用该库的简单Java程序时,一切正常,但是当我通过JNI执行相同的代码时,库在从String解析Integer时会抛出Null异常。我确信我的JNI代码没有问题,因为我有一个更新版本的库具有相同的接口,可以通过JNI正常工作。但不幸的是,由于与外部系统的兼容性问题,我不得不使用旧版本。

我认为问题在于jvm.dll如何创建VM - 我可能错过了一些在创建VM时应该传递给jvm.dll的参数。有谁知道问题出在哪里?

我无法发布我的代码,但我可以在示例中解释它: - 库版本1 contatins类路由器与构造函数Router(int i) - 我没有这个类的代码 - 库版本2包含具有相同构造函数的相同类 - 当我写简单程序时

import java.lang.reflect.*;

public class Basic
{
    public static void main(String[] args)
    {
        Router = new Router(10); 
    }
}

它适用于两个库。

当我通过JNI使用较新的库2运行相同的代码时,它也可以工作。 但是当我通过JNI使用库1运行代码时,由于跟随内部异常

而崩溃
    Error message: System.Exception: JAVA Exception: java.lang.NullPointerException
at com.coda.core.types.TypeNumber.parseNumber(TypeNumber.java:403)
at com.coda.core.types.TypeInteger.parse(TypeInteger.java:123)
at com.coda.core.types.TypeInteger.parse(TypeInteger.java:137)
at com.coda.core.Options.setOption(Options.java:138)
at com.coda.core.Options.set(Options.java:85)
at com.coda.core.configuration.ConfigurationLoader.getConfiguration(ConfigurationLoader.java:144)
at com.coda.xml.Configuration.init(Configuration.java:453)
at com.coda.xml.Configuration.init(Configuration.java:370)
at com.coda.xml.router.AppServer.<init>(AppServer.java:250)
at com.coda.xml.router.Router.<init>(Router.java:122)

1 个答案:

答案 0 :(得分:0)

我已经解决了这个问题。我在JVM的参数方面确实存在错误。较旧的库需要另一个我不知道的jar库。所以我已经将库添加到类路径中并且工作正常。真的很愚蠢的例外,没有说消息让我以错误的方式寻找问题。

感谢大家的评论