问题是找出哪些 Java 函数调用了一些 JNI 函数。在 Java 中,这将通过 来实现new Exception.printStackTrace()
,但这必须通过本机 (JNI) 函数来完成。
由于以后查找自己的代码的最简单方法是将其发布在“网络”中,因此我将问题和答案都发布了。
问题是找出哪些 Java 函数调用了一些 JNI 函数。在 Java 中,这将通过 来实现new Exception.printStackTrace()
,但这必须通过本机 (JNI) 函数来完成。
由于以后查找自己的代码的最简单方法是将其发布在“网络”中,因此我将问题和答案都发布了。
JNI 的模拟new Exception.printStackTrace()
是:
//#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}");
}
顺便说一句,您可以从本机层向 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 中获取堆栈跟踪。