前几天用到了jni,在开发中遇到一问题,就是我在android studio的c代码中添加了一个打印log的代码,如下:
#include <android/log.h>
//#define LOGV(...) __android_log_print(ANDROID_LOG_VERBOSE, TAG, __VA_ARGS__)
//#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG , TAG, __VA_ARGS__)
//#define LOGI(...) __android_log_print(ANDROID_LOG_INFO , TAG, __VA_ARGS__)
//#define LOGW(...) __android_log_print(ANDROID_LOG_WARN , TAG, __VA_ARGS__)
//#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR , TAG, __VA_ARGS__)
然后便在代码中愉快的打印log了,可是在编译的时候却报了这个错。Error:(271) undefined reference to `__android_log_print'
当时的我是一脸懵逼,赶紧开始万能的百度、谷歌,然而并没有什么卵用,没有找到原因。就在我绝望的时候,友谊的小船开来了,一个朋友帮我找到
了解决办法。具体解决办法如下:
将写好的jni文件 直接拿出来到一个单独的目录 一定要是单独的 比如 在d盘新建一个文件夹 然后放进去 。
第一步:将android studio 写好的jni文件 整体拿到一个全新的 目录下
第二步:cmd 进入到这个jni文件夹的 父目录
第三步:在该目录下直接运行ndk-build命令即可
第四步:会在jni的同一级目录生成 libs文件夹 里面有各种处理器的.so
so easy,这样编译通过了,生成了我们想要的so文件了。