1:需要在c/c++部分打印log信息
1)在Android.mk文件中添加
LOCAL_LDLIBS += -lc -lm -llog
2)引用头文件:
#include <android/log.h>
#define LOG_TAG "hellojni"
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO,LOG_TAG,__VA_ARGS__)
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,LOG_TAG,__VA_ARGS__)
使用方法:
LOGI("这是一个测试,this is a test!", "hehe");
2:需要支持c++的异常处理功能和RTTI:
1)支持异常处理:
此问题的出现是编译器的异常异常捕获被禁用了,需要在Android.mk文件中开启。在Android.mk文件中添加:
LOCAL_CPPFLAGS += -fexceptions
或者在Application.mk文件中添加
APP_CPPFLAGS += -fexceptions
2)支持RTTI:
NDK从r5开始支持异常处理,但为兼容以前的版本,默认是不开启此功能的,即-fno-exceptions。从NDK r5开始,NDK工具链也开始支持C++ RTTI(Runtime Type Information)了,但默认也是不开启,需要在Android.mk中添加:LOCAL_CPPFLAGS += -frtti,或在Application.mk添加APP_CPPFLAGS += -frtti
3:编译时发生异常:warning: this decimal constant is unsigned only in ISO C90
参见解决方法:http://forum.ubuntu.org.cn/viewtopic.php?t=288895
4:在C++中调用jni接口发生'base operand of '->' has non-pointer type '_JNIEnv''错误:
参见:http://blog.csdn.net/autumn20080101/article/details/8247500
5:java调用jni接口发生异常:java.lang.UnsatisfiedLinkError: Native method not found:
1)原因是使用c++开发,需要加上
extern "C"{
。。。
}
例如:
extern "C" {
JNIEXPORT jstring JNICALL Java_com_visualgdb_example_AndroidProject3_AndroidProject3_stringFromJNI(JNIEnv* env, jobject thiz);
JNIEXPORT jstring JNICALL Java_com_visualgdb_example_AndroidProject3_AndroidProject3_testFromJNI(JNIEnv* env, jobject thiz);
}
2)jni接口函数名没有与android方法名对应。