如何从java本机接口调用getStackTrace方法(jni)

问题描述 投票:0回答:1

我试图用一些例子来理解jni。我试图使用jni获取java堆栈跟踪,所以这就是我正在做的事情

hello JNI.Java

package test.com.jni;

public class HelloJNI {
    static {
        System.loadLibrary("hello"); // Load native library at runtime
    }

    private native StackTraceElement[] getStackTraceNative(Throwable throwable);
    private native void printStackTraceNative(Throwable throwable);

    public static void main(String[] args) {
        test();
    }

    public static void test() {
        new HelloJNI().printStackTraceNative(new Throwable()); //Invoke native method
        new HelloJNI().getStackTraceNative(new Throwable());
    }
}

本机代码(为简单起见,保持错误处理)

test_com_jni_HelloJNI.c

JNIEXPORT jobjectArray JNICALL Java_test_com_jni_HelloJNI_getStackTraceNative (JNIEnv * env, jobject object, jthrowable exception) {

    jclass exceptionClazz = (*env)->GetObjectClass(env, exception); 

    jmethodID getStackTraceMethod = (*env)->GetMethodID(env, exceptionClazz, "getStackTrace", "()[Ljava.lang.StackTraceElement");

    jobjectArray stacktraces = (*env)->CallObjectMethod(env, exception, getStackTraceMethod);

    return stacktraces;
}

JNIEXPORT void JNICALL Java_test_com_jni_HelloJNI_printStackTraceNative (JNIEnv * env, jobject object, jthrowable exception) {

    jclass exceptionClazz = (*env)->GetObjectClass(env, exception); // can't fail

    jmethodID printStackTraceMethod = (*env)->GetMethodID(env, exceptionClazz, "printStackTrace", "()V");

    (*env)->CallVoidMethod(env, exception, printStackTraceMethod);
}

现在在这个代码中本机printStackTraceNative方法工作,它打印堆栈跟踪,但getStackTraceNative没有。当我检查核心转储文件时,它说java已经为java/lang/NoSuchMethodError抛出了一个异常getStackTrace。我很困惑,因为我传递给getStackTraceNative方法的参数是throwable类型,throwable应该有方法getStackTrace

我可能在这里缺少什么概念,对此有任何帮助表示赞赏。谢谢

java java-native-interface
1个回答
1
投票

你的方法签名错了。在方法签名中,限定类名称中的句点将由正斜杠替换。因此,getStackTrace的签名是()[Ljava/lang/StackTraceElement;(也注意分号)

您可以使用带有javap选项的-s从类文件中获取方法签名:

javap -classpath '/path/to/jre/lib/rt.jar' -s java.lang.Throwable
© www.soinside.com 2019 - 2024. All rights reserved.