在android C/C++ native编程(ndk)中使用logcat

原创 2012年03月29日 12:39:25
最近在研究Android 2.2 源代码的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 Studio NDK 入门教程(4)--优雅的在C++中输出Logcat

本文描述如何在C/C++中输出Logcat日志
  • venusic
  • venusic
  • 2016年08月23日 21:49
  • 4514

android NDK下log的使用和封装

参考: Android Studio 上如何使用LogCat:http://blog.csdn.net/u012005313/article/details/47747997 Android log...

Android NDK开发(三)——常见错误集锦以及LOG使用

Android NDK开发经常因某些因素会出现一些意想不到的错误,很多时候调试这些错误的时候,显得比调试Java代码要复杂,一方面是导致错误的原因很多很杂,另一方面NDK开发涉及到C/C++代码的编写...

ANDROID NDK实践开发系列--(01) 使用ndk编译c可执行程序

本文我们研究一下怎么使用ndk开编译c语言编写的可执行程序。 原创作品转载请注明出处哦http://blog.csdn.net/superfang119/article/details/852413...

安卓 jni C/C++ logcat 调试输出

最近在弄 ndk jni,记录下调试技巧 在代码中加入 #include  #define LOG_TAG  “jnidebug” #define LOGV(...) __android_log_p...
  • zlw1005
  • zlw1005
  • 2013年12月27日 16:45
  • 1715

如何在android C/C++ native编程(ndk)中使用logCat

http://bbs.theithome.com/simple/?t896.html.   最近在研究Android 2.3.3源代码的C/C++层,需要对代码进行一些调试,但是奇怪的是,直接...

Android:Native C源码(NDK)如何使用sqlite3进行编程?

1. 首先要#include 如果遇到以下错误: /home/andy/Desktop/andy/Android/alps/development/salemanagerd/salemanage...
  • annkie
  • annkie
  • 2012年09月18日 18:18
  • 4409

android studio中使用ndk编译.so文件,调用C/C++代码(jni编程)

android studio中使用ndk编译.so文件,调用C/C++代码(jni编程)一.前言 什么是NDK? NDK全称是Native Development Kit,NDK提供了一系列的工具...

使用NDK生成native C/C++的可执行程序

众所周知, NDK可以生成lib,让java程序通过jni来调用,其实,NDK也可以生成C/C++的可执行程序.不过这个程序要被执行的话还有要求.    1.可执行文件的名字必须是lib*.so...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:在android C/C++ native编程(ndk)中使用logcat
举报原因:
原因补充:

(最多只允许输入30个字)