您的位置:首页 > 运维架构 > Linux

分别在Linux和Android中用C语言写系统日志

2011-01-27 15:06 543 查看
写程序难免需要用到调试信息,由于某些原因,有的调试信息想把它放到系统日志中去。因此今天试验了一下分别在Linux和Android中用C语言写系统
日志。首先是在Linux中尝试写系统日志,关于这方面的资料网上已经很多了,我先把我的代码贴到下面吧。
/****************************** syslog.c
***********************************/

#include<stdio.h>

#include<stdlib.h>

#include<syslog.h>

int main()

{

int i;

/************ 添加第一段错误记录 ************/

/*openlog函数用于打开系统日志连接,调用openlog是可选择的。如果不调用openlog,则在第一次调用syslog时,自动调用
openlog。调用openlog 使我们可以指定一个ident,以后, 此ident 将被加至每则记录消息中。ident
一般是程序的名称(例如 ,cron ,ine 等)*/

openlog("syslog实验A--错误",LOG_CONS|LOG_PID,LOG_LOCAL0);/*openlog函数中的第1个参数为
ident,该参数常用来表示信息的来源。ident指向的字符信息会被固定地添加在每行日志的前面。第2个参数option用于指定openlog函数
和接下来调用的syslog函数的控制标志。第3个参数为facility*/

for(i=0;i<3;i++)

syslog(LOG_ERR,"添加实验A的第%d条错误记录。/n",i);/*第一个参数是消息的紧急级别,第二个参数是消息的格式,之后是格式对应的参数。就是printf函数一样使用。*/

closelog();

/************ 添加第二段错误记录 ************/

openlog("syslog实验B--警告",LOG_CONS|LOG_PID,LOG_LOCAL1);

for(i=0;i<2;i++)

syslog(LOG_WARNING,"添加实验B的第%d条警告记录。/n",i);

closelog();

return 0;

}=================================================


序运行后终端没有什么反应,但是用tail /var/log/syslog查看的话(需要root权限),可以看到后面添加了以下五行:Mar 31
18:38:54 admin-desktop syslog实验A--错误[10369]: 添加实验A的第0条错误记录。

Mar 31 18:38:54 admin-desktop syslog实验A--错误[10369]: 添加实验A的第1条错误记录。

Mar 31 18:38:54 admin-desktop syslog实验A--错误[10369]: 添加实验A的第2条错误记录。

Mar 31 18:38:54 admin-desktop syslog实验B--警告[10369]: 添加实验B的第0条警告记录。

Mar 31 18:38:54 admin-desktop syslog实验B--警告[10369]: 添加实验B的第1条警告记录。

这方面的资料比较多,可以参看以下文章:http://book.csdn.net/bookfiles/545/10054518311.shtml
http://www.sudu.cn/info/html/edu/20060101/297778.html http://blog.csdn.net/yulanarti/archive/2007/09/13/1783839.aspx上面程序中标为蓝色的注释也是在网上的文章中摘过来的。
=========================================
然后再进行在Android上写日志文件的实验,但是把这个程序编译到Android上,运行之后却找不到日志写到什么地方去了。Android下没有
var目录,而且用logcat查看后也发现自己的信息没有加入到日志中。后来在网上找了一下资料,又回想了源码中的一些情景,试着用了LOGD来输出信
息到日志,果然成功了。现把代码贴到下面:/********************** 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.cLOCAL_SHARED_LIBRARIES := /

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

LOCAL_C_INCLUDES := /

$(JNI_H_INCLUDE)LOCAL_PRELINK_MODULE := falseLOCAL_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后面的字母就是它们输出信息种类的单词的首字母。关于这几个宏的详细使用场合可参看这篇文章()。里面介绍的比较详细,是用
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分别对应的是调试、出错、消息、警告。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: