NDK使用log的问题

 

 

1如果要用log,那就要把 liblog给引进来。Android.mk中加LOCAL_LDLIBS := -llog

2在编译so文件的ccpp文件之前中加入以下代码,就可以在android中的log显示日志内容

#include <android/log.h>

__android_log_write(ANDROID_LOG_WARN,”biqian”,”neirong”);或

__android_log_print(ANDROID_LOG_WARN,”biqian”,”neirong”)

logcat的级别:

    ANDROID_LOG_UNKNOWN,
    ANDROID_LOG_DEFAULT,  
    ANDROID_LOG_VERBOSE,
    ANDROID_LOG_DEBUG,
   
ANDROID_LOG_INFO,
    ANDROID_LOG_WARN,
    ANDROID_LOG_ERROR,
    ANDROID_LOG_FATAL,
    ANDROID_LOG_SILENT

 

注意:如果在Android.mk中不加LOCAL_LDLIBS := -llog 直接编译,就会报 __android_log_write 方法undefined.

怎么回事呢?关键是在设置编译选项上面。
Android.mk文件里,可以指定一个LOCAL_LDLIBS的参数。如果不指定,那么编译的时候,只会引入默认的几个重要的lib,比如libc之类的。
  如果要用log,那就要把 liblog给引进来。
  网上很多的写法是 LOCAL_LDLIBS := -llog ,这在build static lib的时候没什么问题。如果是build shared lib,就会报个 cannot find -llog的错误。意思是找不到liblog.so这个库文件。
  因此需要改成 LOCAL_LDLIBS :=  -L$(SYSROOT)/usr/lib -llog 才可以正常编译。
  其中-L参数是指定了搜索lib的路径。
  下面是一个android.mk的内容的例子:
  LOCAL_PATH := $(call my-dir)
  include $(CLEAR_VARS)
  LOCAL_MODULE    := TestNdkNetwork
  LOCAL_SRC_FILES := HttpConnection.cpp
  LOCAL_LDLIBS := -L$(SYSROOT)/usr/lib -llog
  include $(BUILD_SHARED_LIBRARY)

我的话费充值店-各种面额
电信100元仅售98.60 

联通100仅售99.00
移动100仅售99.30

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值