关于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,还请各位来访的朋友多加指点,谢谢!