首页 > 代码库 > Jni 异常捕获
Jni 异常捕获
Jni 异常捕获
http://192.210.60.138/dz/forum.php?mod=viewthread&tid=19&fromuid=1
(出处: IStudy)
#define LOG_TAG "JNIHelp"#include "JNIHelp.h"#include "android/log.h"#include <string.h>#include <assert.h>#include <stdio.h>#include <stdlib.h>/* * Register native JNI-callable methods. * "className" looks like "java/lang/String" */static void getExceptionSummary(JNIEnv* env, jthrowable exception, char* buf, size_t bufLen){ int success = 0; /* get the name of the exception‘s class */ jclass exceptionClazz = env->GetObjectClass(exception); // can‘t fail jclass classClazz = env->GetObjectClass(exceptionClazz); // java.lang.Class, can‘t fail jmethodID classGetNameMethod = env->GetMethodID(classClazz, "getName", "()Ljava/lang/String;"); jstring classNameStr = static_cast<jstring>(env->CallObjectMethod(exceptionClazz, classGetNameMethod)); if (classNameStr != NULL) { /* get printable string */ const char* classNameChars = env->GetStringUTFChars( classNameStr, NULL); if (classNameChars != NULL) { /* if the exception has a message string, get that */ jmethodID throwableGetMessageMethod = env->GetMethodID( exceptionClazz, "getMessage", "()Ljava/lang/String;"); jstring messageStr = static_cast<jstring>(env->CallObjectMethod(exception, throwableGetMessageMethod)); if (messageStr != NULL) { const char* messageChars = env->GetStringUTFChars( messageStr, NULL); if (messageChars != NULL) { snprintf(buf, bufLen, "%s: %s", classNameChars, messageChars); env->ReleaseStringUTFChars( messageStr, messageChars); } else { env->ExceptionClear(); // clear OOM snprintf(buf, bufLen, "%s: <error getting message>", classNameChars); } env->DeleteLocalRef( messageStr); } else { strncpy(buf, classNameChars, bufLen); buf[bufLen - 1] = ‘\0‘; } env->ReleaseStringUTFChars( classNameStr, classNameChars); success = 1; } env->DeleteLocalRef( classNameStr); } env->DeleteLocalRef( classClazz); env->DeleteLocalRef( exceptionClazz); if (! success) { env->ExceptionClear(); snprintf(buf, bufLen, "%s", "<error getting class name>"); }}/* Throw an exception with the specified class and an optional message.*/int jniThrowException(JNIEnv* env) { jclass exceptionClass; int result = 0; if (env->ExceptionCheck()) { /* TODO: consider creating the new exception with this as "cause" */ char buf[256]; jthrowable exception = env->ExceptionOccurred(); env->ExceptionClear(); if (exception != NULL) { getExceptionSummary(env,exception, buf, sizeof(buf)); //LOGW("Discarding pending exception (%s) to throw %s\n", buf, className); __android_log_print(ANDROID_LOG_INFO, "", "Discarding pending exception (%s) to throw\n",buf); env->DeleteLocalRef(exception); result = -1; } } return result; }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。