ndk开发注意事项小记

1:需要在c/c++部分打印log信息

1)在Android.mk文件中添加

LOCAL_LDLIBS += -lc -lm -llog


2)引用头文件:

#include <android/log.h>


3)自定义宏,方便使用:

#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方法名对应。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值