在Android C/C++层添加LOG调试(LOGI\LOGD\LOGE...)输出支持
来源:互联网 发布:java的注解有哪些 编辑:程序博客网 时间:2024/04/29 11:30
转自:http://blog.163.com/cy_7157@126/blog/static/140101255201222021918903/
最 近在研究Android 2.3.3源代码的C/C++层,需要对代码进行一些调试,但是奇怪的是,直接添加LOGD("XXXXXXXX");,使用logcat却看不到任何输出,换成LOGI、LOGV、LOGW、LOGE也没有效果。于是在网上查找解决方法,经过几次试验,终于找到了,现在贴到下面备忘:
第一步:在对应的mk文件中加入:LOCAL_LDLIBS:= -llog
第二步:在要使用LOG的cpp文件中加入:
#include <android/log.h>
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,"keymatch", __VA_ARGS__)
第三步:这样就可以使用了:LOGD("我要看到的调试信息^_^");
这样,在logcat端看到的输出是:
D/keymatch( 32):我要看到的调试信息^_^
如果想改变输出中的各项内容,可以参考相应颜色的标示,比如,如果想定义LOGE,就可以把上面的ANDROID_LOG_DEBUG改成ANDROID_LOG_ERROR,同理,LOGI神马的也都以此类推:
#define LOGV(...)__android_log_print(ANDROID_LOG_VERBOSE, "ProjectName", __VA_ARGS__)
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG ,"ProjectName", __VA_ARGS__)
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO ,"ProjectName", __VA_ARGS__)
#define LOGW(...) __android_log_print(ANDROID_LOG_WARN ,"ProjectName", __VA_ARGS__)
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR ,"ProjectName", __VA_ARGS__)
当然,如果不嫌麻烦,也可以直接使用__android_log_print函数,而不define定义LOGxxx
如果还想了解更详细的内容,也可以参考这篇文章: 《在android输出log 信息 用于调试》
另外,有文章称此方法在编译动态库的时候可能会出问题,会提示cannot find -llog的错误。意思是找不到liblog.so这个库文件。
因此需要改成LOCAL_LDLIBS:= -L$(SYSROOT)/usr/lib -llog才可以正常编译。但是我这边编译动态库的时候,好像不用这样改也行,没发现编译时提示“cannot find -llog”的错误。如果您在实践过程中发现有这样的问题,可以参考该文章,链接在此:《如何在android native编程中使用logCat》
- 在Android C/C++层添加LOG调试(LOGI\LOGD\LOGE...)输出支持
- 在Android C/C++层添加LOG调试(LOGI\LOGD\LOGE...)输出支持 开花结果
- 在Android C/C++层添加LOG调试(LOGI\LOGD\LOGE...)输出支持 开花结果
- 在Android C/C++层添加LOG调试(LOGI\LOGD\LOGE...)输出支持
- 在Android C/C++层添加LOG调试(LOGI\LOGD\LOGE...)输出支持
- 在Android C/C++层添加LOG调试(LOGI\LOGD\LOGE...)输出支持
- 在Android C/C++层添加LOG调试(LOGI\LOGD\LOGE...)输出支持
- 在Android C/C++层添加LOG调试(LOGI\LOGD\LOGE...)输出支持
- 在Android C/C++层添加LOG调试(LOGI\LOGD\LOGE...)输出支持
- 在Android C/C++层添加LOG调试(LOGI\LOGD\LOGE...)输出支持
- 在Android C/C++层添加LOG调试(LOGI\LOGD\LOGE...)输出支持
- 在Android C/C++层添加LOG调试(LOGI\LOGD\LOGE...)输出支持
- 在Android C/C++层添加LOG调试(LOGI\LOGD\LOGE...)输出支持
- 在Android C/C++层添加LOG调试(LOGI/LOGD/LOGE
- 在Android C/C++层添加LOG调试输出调试
- 在Android C/C++层添加LOG调试
- Android C 层如何输出log
- 如何屏蔽LOGD\LOGI等打印输出
- H.265:网络视频的高清时代 转载自:果壳网
- ORACLE 基本管理
- Framework Pattern: Consulting Pattern Series
- C# 16进制与字符串、字节数组之间的转换
- struts2拦截器+监听器
- 在Android C/C++层添加LOG调试(LOGI\LOGD\LOGE...)输出支持
- Active Object 中的 C++例子
- HTTPS和HTTP的区别
- 文档在线预览(三)- 使用SWFTools转换文档为SWF格式
- ORACLE 配置访问mysql 数据库
- 常用数据库jdbc连接字符串总结
- 修改Win7启动顺序和启动菜单名称
- 子衿的事(72)
- shell中特殊变量$0 $1 $# $$ $! $?的涵义