从JNI调用exception.printStackTrace()

时间:2013-04-11 05:23:42

标签: android java-native-interface

问题是要找出哪些Java函数调用了一些JNI函数。在Java中,这将通过new Exception.printStackTrace()实现,但必须从本机(JNI)函数完成。

由于以后查找自己代码的最简单方法是将其发布到'net,我发布问题和答案。

2 个答案:

答案 0 :(得分:4)

new Exception.printStackTrace()的JNI模拟是:

//#include <android/log.h>
//#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG  , "~~~~~~", __VA_ARGS__)
//#define DLOG(...) __android_log_print(ANDROID_LOG_DEBUG  , "~~~~~~", __VA_ARGS__)
void printStackTrace(JNIEnv *env) {
LOGD("###################################################################################printStackTrace{");
    jclass cls = env->FindClass("java/lang/Exception");
    if (cls != NULL) {
        jmethodID constructor = env->GetMethodID(cls, "<init>", "()V");
        if(constructor != NULL) {
            jobject exc = env->NewObject(cls, constructor);
            if(exc != NULL) {
                jmethodID printStackTrace = env->GetMethodID(cls, "printStackTrace", "()V");
                if(printStackTrace != NULL) {
                    env->CallObjectMethod(exc, printStackTrace);
                } else { DLOG("err4"); }
            } else { DLOG("err3"); }
            env->DeleteLocalRef(exc);
        } else { DLOG("err2"); }
    } else { DLOG("err1"); }
    /* free the local ref */
    env->DeleteLocalRef(cls);
LOGD("###################################################################################printStackTrace}");
}

答案 1 :(得分:0)

顺便说一下,你可以将异常从本机层抛出到Java :) 像这样:

jint throwOutOfMemoryError( JNIEnv *env, char *message ){
    jclass       exClass;
    char *className = "java/lang/OutOfMemoryError" ;

    exClass = (*env)->FindClass( env, className );
    if ( exClass == NULL ){
        return throwNoClassDefError( env, className );
    }
    return (*env)->ThrowNew( env, exClass, message );
}

或者如果你有一个Exception实例,只需将它放入Java层,然后用Java获取堆栈跟踪。