在android C/C++ native编程(ndk)中使用logcat
来源:互联网 发布:ibatis源码下载 编辑:程序博客网 时间:2024/06/02 06:46
最近在研究Android 2.2 源代码的C/C++层,需要对代码进行一些调试,但是奇怪的是,直接添加LOGD("XXXXXXXX");,使用logcat却看不到任何输出,换成LOGI、LOGV、LOGW、LOGE也没有效果。于是在网上查找解决方法,经过几次试验,终于找到了,现在贴到下面备忘:
第一步:在对应的mk文件中加入:LOCAL_LDLIBS := -llog
第二步:在要使用LOG的cpp文件中加入:
第三步:这样就可以使用了:LOGD("我要看到的调试信息^_^");
这样,在logcat端看到的输出是:
D/keymatch( 32):我要看到的调试信息^_^
如果想改变输出中的各项内容,可以参考相应颜色的标示,比如,如果想定义LOGE,就可以把上面的ANDROID_LOG_DEBUG改成ANDROID_LOG_ERROR,同理,LOGI神马的也都以此类推:
当然,如果不嫌麻烦,也可以直接使用__android_log_print函数,而不define定义LOGxxx
如果还想了解更详细的内容,也可以参考这篇文章: 《在android 输出log 信息 用于调试》
另外,有文章称此方法在编译动态库的时候可能会出问题,会提示cannot find -llog的错误。意思是找不到liblog.so这个库文件。
因此需要改成 LOCAL_LDLIBS:= -L$(SYSROOT)/usr/lib -llog 才可以正常编译。但是我这边编译动态库的时候,好像不用这样改也行,没发现编译时提示“cannot find -llog”的错误。
第一步:在对应的mk文件中加入:LOCAL_LDLIBS := -llog
第二步:在要使用LOG的cpp文件中加入:
- #include <android/log.h>
- #define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, "keymatch", __VA_ARGS__)
这样,在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”的错误。
0 0
- 在android C/C++ native编程(ndk)中使用logCat
- 在android C/C++ native编程(ndk)中使用logcat
- 在android C/C++ native编程(ndk)中使用logCat
- 在android C/C++ native编程(ndk)中使用logcat
- 如何在android C/C++ native编程(ndk)中使用logCat
- 在android C/C++ native编程(ndk)中使用logCat学习记录
- 如何在android native编程中使用logCat
- 如何在android native编程中使用logCat
- 如何在android native编程中使用logCat
- Android:Native C源码(NDK)如何使用sqlite3进行编程?
- Android环境在C代码中使用logcat获取log
- Android JNI(3) --在C代码中使用logcat
- 在c代码中使用logcat
- 在c代码中使用logcat
- 使用GDB调试Android NDK native(C/C++)程序
- 使用GDB调试Android NDK native(C/C++)程序
- 使用GDB调试Android NDK native(C/C++)程序
- 使用GDB调试Android NDK native(C/C++)程序
- Java线程(一):传统线程的实现、互斥与通信
- OpenStack 2014 用户调查解析——中国部署规模仅次于美国
- LaTeX制作动图效果
- 如何学好网络博客推广技术
- 程矢Axure夜话:中继器系列视频教程之中继器表格删除数据2
- 在android C/C++ native编程(ndk)中使用logcat
- ViewOverlay: When, How and for What Purpose?
- 程矢Axure夜话:中继器系列视频教程之中继器表格删除数据
- 大苏打撒旦撒旦撒旦啊撒旦
- const A& fun(const A& a) const {} 的理解
- 此主题相关图片如下
- WebService大数据量时异常
- session与cookie的区别
- 程矢Axure夜话:中继器系列视频教程之中继器表格奇偶行换色2