问题是要找出哪些Java函数调用了一些JNI函数。在Java中,这将通过new Exception.printStackTrace()
实现,但必须从本机(JNI)函数完成。
由于以后查找自己代码的最简单方法是将其发布到'net,我发布问题和答案。
答案 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获取堆栈跟踪。