关于android底层库编译出现“undefined reference to `android_log_print'”的解决办法
关于android底层库编译出现“undefined reference to `__android_log_print'”的解决方法
问题描述:
很多时候,我们需要在自己的android应用程序中调用到其它语言(C)编写的高效率底层模块,一般通过 System.loadLibrary(libname) 来实现,同时我们还需要调试这个用C写的库,在 .c 源文件中打印 log 信息。
方法步骤:
1、在源文件中添加如下头文件:
#include <utils/Log.h>
2、在 Android.mk 文件中包含相关的库:
- 如果你生成的模块是一个共享库(.so),则将相关的库文件包含入共享库目录:
... ...
LOCAL_SHARED_LIBRARIES := liblog libcutils #相关的库文件,加入共享库目录
... ...
include $(BUILD_SHARED_LIBRARY) #注意:生成共享库 .so 文件
- 如果你生成的模块不是一个共享库,比如是可执行文件,则将相关的库文件包含入静态库目录:
... ...
LOCAL_STATIC_LIBRARIES := liblog libcutils #相关的库文件,加入静态库目录
... ...
include $(BUILD_EXECUTABLE) #注意:生成可执行文件
3、在源代码中需要打印 log 的地方执行:
LOGE(logformat); //如:LOGE("my num is: %d", i); 或者LOGD, LOGW,大家应该知道怎么区别吧
讨论与问题
网上很多方法并没有区别生成的模块类别,而只是统一默认为生成共享库文件(.so)的情况,对于生成可执行文件的情况则未加讨论。这里我提供的生成可执行文件的配置方法貌似还有问题:这样配置可以保证编译不出现 “undefined reference to `__android_log_print” 错误,但是运行时却仍然无法打印 log,还请各位来访的朋友多加指点,谢谢!