java – 将对象创建移动到另一个方法后的JNI总线错误

我有一个问题,JNI整天带我走,如果我不打电话求助,可能会让我感到疯狂.

在两个短语中:我从JNI方法调用NewObject并且它工作正常,但是当我将此代码移动到另一个方法时,它会崩溃.

更多细节:

我有这个简单的类,我想从JNI C/C++代码创建它的实例:

package example;

public class ModelDetails {
    public ModelDetails() { ... }
}

具有本机方法的类如下:

package example;
public class JNIWrapper {
     public native ModelDetails getModelDetails() throws SomeException;
}

以下代码非常好用:

jclass    modelDetailsClass           = NULL;
jmethodID modelDetailsConstMid        = NULL;

JNIEXPORT jobject JNICALL Java_example_JNIWrapper_getModelDetails
 (JNIEnv *env,jobject jobj) {

    cout << "getModelDetails c++" << endl;

    // ModelDetails class
    if (!modelDetailsClass) { // reuse class
        modelDetailsClass = env->FindClass("example/ModelDetails");
    }
    if (!modelDetailsClass) { // check if findclass was successful
        throwJavaException(env,"Could not get class ModelDetails");
        return NULL;
    }
    cout << "model detail class: " << modelDetailsClass << endl;

    // constructor
    if (!modelDetailsConstMid) { // reuse method id
        modelDetailsConstMid = env->GetMethodID(modelDetailsClass,"

但是,由于我必须在这个函数Java_example_JNIWrapper_getModelDetails中做很多事情,所以我决定将这个对象的创建移动到另一个函数

jobject fillModelDetails(JNIEnv *env,jobject jobj) {
    cout << "fillModelDetails" << endl;

    // ModelDetails class
    if (!modelDetailsClass) { // reuse class
        modelDetailsClass = env->FindClass("example/ModelDetails");
    }
    if (!modelDetailsClass) { // check if findclass was successful
        throwJavaException(env,"Could not get ModelDetails constructor method id");
        return NULL;
    } 

    // create object
    jobject mdetails = env->NewObject(modelDetailsClass,"Could not create ModelDetails instance");
        return NULL;
    }

    return mdetails;
}

这样,在Java_example_JNIWrapper_getModelDetails中我只调用fillModelDetails(env,jobj);

问题是现在我在NewObject行遇到了一个总线错误.

Invalid memory access of location 0x9 eip=0x475fe1

题:
有谁知道为什么我不应该从另一个方法调用构造函数?这看起来很奇怪.

感谢任何提示,想法,评论……

编辑:

我刚添加-Xcheck:jni并收到此错误

FATAL ERROR in native method: Bad global or local ref passed to JNI
at example.JNIWrapper.getModelDetails(Native Method)

所以这让我觉得问题可能是由于使用全局变量中的构造函数和类id引起的.我将这些声明移动到JNI方法中的局部变量,它可以工作.

这真让我感到惊讶,因为我从一段时间以来一直在使用这些全局变量,从来没有遇到任何问题……可能导致这个问题的原因是什么?

最佳答案
我会回答这个问题,因为我发现了问题,但是有关重新使用jclass和jmethodID的另一个问题仍然存在.在这个方向上改变这个问题似乎没有组织,所以我将打开另一个线程.

解决方案是使用局部变量

jclass    modelDetailsClass           = NULL;
jmethodID modelDetailsConstMid        = NULL;

而不是我之前使用的全局变量.

相关文章

ArrayList简介:ArrayList 的底层是数组队列,相当于动态数组。与 Java 中的数组相比,它的容量能动态增...
一、进程与线程 进程:是代码在数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位。 线程...
本文为博客园作者所写:&#160;一寸HUI,个人博客地址:https://www.cnblogs.com/zsql/ 简单的一个类...
#############java面向对象详解#############1、面向对象基本概念2、类与对象3、类和对象的定义格式4、...
一、什么是异常? 异常就是有异于常态,和正常情况不一样,有错误出错。在java中,阻止当前方法或作用域...
Collection接口 Collection接口 Collection接口 Collection是最基本的集合接口,一个Collection代表一组...