问题是找出哪些Java函数调用了一些JNI函数。在Java语言中,这可以通过new Exception.printStackTrace()来实现,但这必须通过本机(JNI)函数来完成。
因为以后找到你自己的代码的最简单的方法就是把它发布到网上,所以我把问题和答案都贴出来了。
发布于 2013-04-11 13:24:18
与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}");
}发布于 2013-04-11 13:29:40
顺便说一下,您可以从原生层向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中获取堆栈跟踪。
https://stackoverflow.com/questions/15941314
复制相似问题