目录
一、问题复现
自己编写的jni代码中用到了打印Android log的方法,并且在Android.mk文件中引入了log库,但是编译时报错(注:如果时Android系统已经全量编译过一次后,然后单独编译这个模块是没有问题的,如果是make clean,然后全量编译,那么就会报错)。
1. Android.mk文件内容
include $(CLEAR_VARS)
LOCAL_MODULE := libsilk8
LOCAL_SRC_FILES := silk8.cpp
LOCAL_C_INCLUDES += $(LOCAL_PATH)/$(SILK)/src $(LOCAL_PATH)/$(SILK)/interface
LOCAL_STATIC_LIBRARIES := libSKP_SILK_SDK
LOCAL_LDLIBS += -llog
LOCAL_ARM_MODE := arm
include $(BUILD_SHARED_LIBRARY)
2. silk8.cpp的部分代码
#include <android/log.h>
#define LOG_I(TAG, ...) __android_log_print(ANDROID_LOG_INFO, TAG, __VA_ARGS__)
#define LOG_E(TAG, ...) __android_log_print(ANDROID_LOG_ERROR, TAG, __VA_ARGS__)
extern "C"
JNIEXPORT jboolean JNICALL Java_com_jack_lib_Test_test(JNIEnv *env, jobject obj){
......
LOG_I(TAG, "测试打印Android log %s ","info level log");
LOG_E(TAG, "测试打印Android log %s ","error level log");
......
}
3. 编译时错误信息
/home/chenjie/repo/300603_3/M3/prebuilts/gcc/linux-x86/aarch64/cit-aarch64-linux-android-4.9/bin/../lib/gcc/aarch64-linux-android/4.9.x-google/../../../../aarch64-linux-android/bin/ld: cannot find -llog
target C++: ui_gl_gl_gyp <= external/chromium_org/ui/gl/android/scoped_java_surface.cc
collect2: error: ld returned 1 exit status
target C++: ui_gl_gl_gyp <= external/chromium_org/ui/gl/android/surface_texture.cc
make: *** [out/target/product/taurus_standard/obj/SHARED_LIBRARIES/libsilk8_intermediates/LINKED/libsilk8.so] Error 1
make: *** Waiting for unfinished jobs....
二、解决方案
1. 在Android.mk文件中加入以下代码
include external/libcxx/libcxx.mk
2. 最终Android.mk文件内容
include $(CLEAR_VARS)
LOCAL_MODULE := libsilk8
LOCAL_SRC_FILES := silk8.cpp
LOCAL_C_INCLUDES += $(LOCAL_PATH)/$(SILK)/src $(LOCAL_PATH)/$(SILK)/interface
LOCAL_STATIC_LIBRARIES := libSKP_SILK_SDK
LOCAL_LDLIBS += -llog
LOCAL_ARM_MODE := arm
# 解决在编译so库时提示 cannot find -llog的问题
include external/libcxx/libcxx.mk
include $(BUILD_SHARED_LIBRARY)
3. make clean,然后全量编译,最终编译成功