android: C log

/********************** log.c *************************/
#include <jni.h>
#include <utils/Log.h>
int main()
{
    LOGD("调试信息!!!!!!!!!!\n");
    return 0;
}


/********************** Android.mk *************************/
LOCAL_PATH:= $(call my-dir)
include $(CLEAR_VARS)

LOCAL_SRC_FILES:= \
    log.c

LOCAL_SHARED_LIBRARIES := \
    libutils \

#如果没有下面这一行,将提示jni.h找不到(error: jni.h: No such file or directory)
LOCAL_C_INCLUDES := \
    $(JNI_H_INCLUDE)


LOCAL_PRELINK_MODULE := false

LOCAL_MODULE:=optional    #如果没有这一句编译可能不通过(转载者注)

LOCAL_MODULE:= syslog_test
include $(BUILD_EXECUTABLE)

===========================
然后编译运行,使用logcat就可以看到我们写的那行信息。

D/        ( 191): 调试信息!!!!!!!!!!



4月1日补充:
用C语言并不是只有LOGD一种方式可以将信息写入日志,查阅android源码/system/core/include/cutils/log.h中的代码后得知,还有其他几种基本的宏,如LOGE、LOGV、LOGI、LOGW等,它们的使用场合是有差别的,关于这点,源码中是这样注释的。

LOGV:Simplified macro to send a verbose log message using the current LOG_TAG
LOGD:Simplified macro to send a debug log message using the current LOG_TAG.
LOGI:Simplified macro to send an info log message using the current LOG_TAG.
LOGW:Simplified macro to send a warning log message using the current LOG_TAG.
LOGE:Simplified macro to send an error log message using the current LOG_TAG.


可见,LOG后面的字母就是它们输出信息种类的单词的首字母。

关于这几个宏的详细使用场合可参看这篇文章(
《GoogleAndroid中打印日志》 )。里面介绍的比较详细,是用java语言举的例子。如果想在C语言程序中调用这几个宏,可以参考本文中的例子。

对昨天写的log.c作如下修改,将5个宏都添加进去。

/********************** log.c *************************/
#include <jni.h>
#include <utils/Log.h>
int main()
{
    LOGD("调试!!!!!!!!!!\n");
    LOGE("出错!!!!!!!!!!\n");
    LOGV("详述!!!!!!!!!!\n");
    LOGI("消息!!!!!!!!!!\n");
    LOGW("警告!!!!!!!!!!\n");
    return 0;
}

编译运行后,有一个比较奇怪的现象,就是LOGV没有输出到logcat,其他四个都有输出,这个还没弄明白是为什么。

// 程序运行结果(使用logcat查看)
D/        ( 193): 调试!!!!!!!!!!
E/        ( 193): 出错!!!!!!!!!!
I/        ( 193): 消息!!!!!!!!!!
W/        ( 193): 警告!!!!!!!!!!

从logcat的每条信息前面的字母也可以看出,D、E、I、W分别对应的是调试、出错、消息、警告。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值