LINUX下C语言编程怎么打印日志

作者&投稿:廖狐 (若有异议请与网页底部的电邮联系)
log-LINUX下C语言编程怎么打印日志~

打印什么日志?
如果是本身程序运行
那么直接前台运行printf就可以了。

如果要把运行结果存成日志,那么
以"a"的方式打开日志文件
然后 fprintf方式写入即可。
写入后 做fclose

需要查看时,cat日志文件。

#include #include #include #include #include #define LOGFILE "./dir_log_0"int g_Count;//#define MAXLEN 1024void WriteDebugLog(char *str);int main(int argc, char **argv){ char str[1024]={0}; strcpy(str,"file no find"); int i=0,j=0; for (i=0; itm_year),(1+p->tm_mon), p->tm_mday,p->tm_hour, p->tm_min, p->tm_sec); //星期p->tm_wday strcat(buf,str); strcat(buf,"
"); strcpy(logFileName,LOGFILE); int len = strlen(logFileName); logFileName[len-1] = '0'+g_Count; fp = fopen(logFileName,"r"); if(fp==NULL) { fp = fopen(logFileName,"w+"); } else { fseek(fp,0,2);//SEEK_END值为2 if( ftell(fp) >= iMax) { fclose(fp); if (g_Count >= 9) { logFileName[len-1] = '0'; g_Count=0; } else { g_Count++; logFileName[len-1] = '0'+g_Count; // printf("
%c",'0'+g_Count); } fp = fopen(logFileName,"w+"); } else { fclose(fp); fp = fopen(logFileName,"a"); } } fwrite(buf,1,strlen(buf),fp); fclose(fp);}

我们的程序一般都会产生输出信息。但是服务器程序一般却不希望输出信息到屏幕上,因为没有人盯着你的程序执行。所以我们要把一些信息写成日志文件,正常情况下运行程序的人不用关心日志里的内容,只有在出现问题的时候才会查看日志文件里的内容以确定问题所在。
但如果我们的程序要自己生成一个文件来保存日志却不是好主意,因为这一方面增加了维护程序运行的人的负担,另一方面自己维护起系统来也多有不便。
在Linux系统中有一个系统日志,通常放在/var/log目录下,比如文件名是syslog的,系统中的一些程序产生的日志信息都会存放到这个文件里。日志文件有固定的格式,比如第1列是消息产生的时间,第2列是机器名(因为日志记录程序支持远程连接),第3列是标记信息(一般就是程序名称)等。而且对应的有一些工具来对这个日志进行维护,比如通过轮回机制保证日志文件大小不会把磁盘空间占尽。所以我们把自己程序的信息也写到这个系统日志里是比较好的想法。
在GNU C语言库提供的内容中,有接口可以用来做这件事。用下面的命令查看:

nm -D /lib/libc.so.6 | grep log

可以看到一些调用:

000b9410 T closelog
0008b870 T getlogin
0008b960 T getlogin_r
000d0180 T __getlogin_r_chk
000bd190 T klogctl
00027450 T __open_catalog
000b9380 T openlog
0008bae0 T setlogin
000b8b80 T setlogmask
000b9350 T syslog
000b9320 T __syslog_chk
000b92f0 T vsyslog
000b8da0 T __vsyslog_chk

这里面的三个函数openlog, syslog, closelog是一套系统日志写入接口。另外那个vsyslog和syslog功能一样,只是参数格式不同。
程序的用法示例代码如下:

#include <syslog.h>
int main(int argc, char **argv)
{
    openlog("MyMsgMARK", LOG_CONS | LOG_PID, 0);
    syslog(LOG_DEBUG,
           "This is a syslog test message generated by program '%s'
",
           argv[0]);
    closelog();
    return 0;
}

编译生成可执行程序后,运行一次程序将向/var/log/syslog文件添加一行信息如下:

   Feb 12 08:48:38 localhost MyMsgMARK[7085]: This is a syslog test message generated by program './a.out'

   Feb 12 08:48:38 localhost MyMsgMARK[7085]: This is a syslog test message generated by program './a.out'

  LOG_CONS
              Write directly to system console if there is an error while sending to system logger.

       LOG_NDELAY
              Open the connection immediately (normally, the connection is opened when the first message is logged).

       LOG_NOWAIT
              Don’t  wait  for  child processes that may have been created while logging the message.  (The GNU C library does not create a
              child process, so this option has no effect on Linux.)

       LOG_ODELAY
              The converse of LOG_NDELAY; opening of the connection is delayed until syslog() is called.  (This is the  default,  and  need
              not be specified.)

       LOG_PERROR
              (Not in SUSv3.) Print to stderr as well.

       LOG_PID
              Include PID with each message.

第三个参数指明记录日志的程序的类型。

syslog函数及参数
syslog函数用于把日志消息发给系统程序syslogd去记录,此函数原型是:
void syslog(int priority, const char *format, ...);
第一个参数是消息的紧急级别,第二个参数是消息的格式,之后是格式对应的参数。就是printf函数一样使用。

如果我们的程序要使用系统日志功能,只需要在程序启动时使用openlog函数来连接syslogd程序,后面随时用syslog函数写日志就行了。

另外,作为syslog的替代程序的新一代工具是syslog-ng,syslog-ng具有很强的网络功能,可以方便地把多台机器上的日志保存到一台中心日志服务器上。



  1. 打印编译的方法有很多,比如在编译时候将其重定向到另一个文件

  2. 或者直接打开某一个文件 在c中直接将参数写入该文件



将日志写到文件中去,在到文件中去看日志

例如:
int mig_log(fmt,va_alist)
char *fmt ;
va_dcl
{
va_list ap ;
FILE *fp ;
char log_file[81] ;
struct tm *p_tm ;
time_t clock ;

ap=(char *)&va_alist ;

time(&clock) ;
p_tm=localtime(&clock) ;

sprintf(log_file,"%s/mig_%4d%.2d%.2d.log",
getenv("HOME"),
p_tm->tm_year+1900,
p_tm->tm_mon+1,
p_tm->tm_mday) ;

fp=fopen(log_file,"at") ;
if(fp==(FILE *)0)
{
fprintf(stderr,"mig_err_log():can't open the file %s !\n",log_file);
return ;
}
fprintf(fp,"%.2d/%.2d/%4d %.2d:%.2d:%.2d ",
p_tm->tm_mon+1,\
p_tm->tm_mday,\
p_tm->tm_year+1900,\
p_tm->tm_hour,\
p_tm->tm_min,\
p_tm->tm_sec) ;
vfprintf(fp,fmt,ap) ;
fclose(fp) ;
}
这个就是写日志的函数

你这样调用:mig_log("日志开始[%s]->[%d]\n",__FILE__,__LINE__) ;
mig_log("日志开始!\n")都可以的

自己写一个打印日志的函数,在你的所有需要打印的地方调用.

5665555653868866555555555


"如何在Linux环境下使用GCC和GDB进行C语言程序开发与调试?"
第1章: C语言开发环境 1.1 Linux操作系统概述: Linux的架构和核心概念为C开发奠定了基础。1.2 Linux开发初步: 学习基本的Linux环境设置和项目初始化。1.3 Linux内核及库文件管理: 理解内核与库文件的组织与管理。1.4 Linux编码风格: 掌握遵循的编程规范和最佳实践。第2章: C语言开发工具 2.1 Li...

在Linux下如何开发C程序?
1.利用编辑器把程序的源代码编写到一个文本文件中。比如编辑test.c程序内容如下:\/*这是一个测试程序*\/ include<stdio.h> int main(void){ printf("Hello Linux!");} 2.用C编译器GCC编译连接,生成可执行文件。gcc test.c 编译完成后,GCC会创建一个名为a.out的文件。如果想要指定输出文件...

Linux运行c语言程序linux运行C语言
怎么在linux中编写c语言程序?先在终端中输入vimtest.c回车进入vim编辑器,再按一下a键,进入编辑状态,然后输入如下C语言语句:includestdio.h>intmain(){printf(helloworld!n);}到此,按esc键退出编辑状态,再输入一个冒号(shift+冒号分号那个键),紧跟着输入wq,即输入:wq按回车,即推出vim编辑器...

Linux环境下C语言编程入门指南linux编程c语言
第一:熟悉C语言的基本语法,以及必要的函数和结构体的概念。要想掌握C语言编程,就必须要理解其基本的语法结构、内置函数实现方式、适当的结构体划分等。第二:要学习Linux操作系统的基本概念,包括文件系统、进程概念、信号量、管道等等,这些概念在C语言编程中都有所体现。第三:了解Linux下如何编译、链...

Linux下使用C语言编写wget工具linuxcwget
在LINUX系统中,我们可以用C语言编写wget工具来下载文件,包括Web、FTP和邮件协议。wget是一个免费的、便捷的开源命令行工具,可以从Web服务器上快速且无需交互地下载文件。首先,我们需要准备以下几个主要的步骤:1.安装 使用GCC编译器,安装必要的库函数库,并下载wget源码:sudo apt-get install build-...

在Linux下用C语言编程
include include include include \/* Linux 的默任个人的邮箱地址是 \/var\/spool\/mail\/用户的登录名 *\/ define MAIL "\/var\/spool\/mail\/hoyt"\/* 睡眠10秒钟 *\/ define SLEEP_TIME 10 main(void){ pid_t child;if((child=fork())==-1){ printf("Fork Error:%s\\n",strerror(errno));exit(...

linux编译c语言命令linux编译c语言
怎么在linux中编写c语言程序?先在终端中输入vimtest.c回车进入vim编辑器,再按一下a键,进入编辑状态,然后输入如下C语言语句:includestdio.h>intmain(){printf(helloworld!n);}到此,按esc键退出编辑状态,再输入一个冒号(shift+冒号分号那个键),紧跟着输入wq,即输入:wq按回车,即推出vim编辑器...

linux终端下如何进行C语言编译
1、首先在linux下判断是否安装gcc编译器,直接执行:gcc -v,判断是否安装gcc。2、然后需要在代码框内写一个简单的C源程序。3、在程序中使用了C语言中的数学开方函数,sqrt(),所以需要引入math.h头文件。4、写完源程序之后,我们对其进行编译,如果使用通常的编译语句,【gcc math.c -o math】进行...

c语言可以在linux下执行吗
c语言可以在linux下执行。Linux下使用最广泛的C\/C++编译器是GCC,大多数的Linux发行版本都默认安装,不管是开发人员还是初学者,一般都将GCC作为Linux下首选的编译工具。GCC(GNU Compiler Collection,GNU编译器集合),是一套由 GNU 开发的编程语言编译器。

Linux系统c语言开发工具linux系统c语言
linux下QT编程是用c语言吗?QT编程一般都用C++,虽然QT的API支持很多语言,但好像没有C,想用C的话你可以使用GTK。Linux语言和c是一样的吗?linux是一个操作系统。而不是一个开发语言。虽然他最初也是用c语言所开发的。但是他和c语言是没有可比性的。所以他和c是不一样的。在linux平台上,C语言...

忻城县15672943436: LINUX下C语言编程怎么打印日志 -
平皆甘油: 将日志写到文件中去,在到文件中去看日志 例如:int mig_log(fmt,va_alist) char *fmt ; va_dcl { va_list ap ; FILE *fp ; char log_file[81] ; struct tm *p_tm ; time_t clock ; ap=(char *)&va_alist ; time(&clock) ; p_tm=localtime(&clock) ; sprintf(log_file,"%s/...

忻城县15672943436: Linux c 程序里面,如何将当前文件的文件名和行号打印出来 -
平皆甘油: printf("%s——%d——%s\n",__FILE__,__LINE__,__FUNCTION__);分别代表文件,行号,函数名

忻城县15672943436: Linux下,一个程序如何获取另一个程序的打印信息 -
平皆甘油: 后台运行的程序运行时为什么不重定向一下…… exe >> file.log

忻城县15672943436: 怎么用C语言实现两个线程在Linux环境下打印 -
平皆甘油: #include <stdio.h> #include <pthread.h>void thread() {pthread_t tid = pthread_self(); while(1){printf("pthread %u\n", tid);sleep(1);} }int main(int argc, char *argv[]) {pthread_t tid = 0; if (0 != pthread_create(&tid, NULL, (void *)thread, NULL...

忻城县15672943436: linux下c++的clock统计时间怎么不准 -
平皆甘油: linux下c++的clock统计时间怎么不准 计时,也就是获取当前的时间,使用 gettimeofday(),精度 1 毫秒.x86_64 ...C语言中如何计算时间差 : C语言中如何计算时间差 如何将两个包含“年月...2)关于sleep中的数,在Windows和Li...linux下如...

忻城县15672943436: Linux下如何编译并运行C程序 -
平皆甘油: 1.编译单个源文件 [例如]在屏幕上打印"Hello,Linux." [源代码]#include#includeint main(int argc,char **argv){printf("Hello,Linux.\n");exit(0);}将源文件保存为hello.c,开始进行编译$gcc -o hello hello.c 编译成功完成后,在当前路径下,生成一个...

忻城县15672943436: linux中如何获取应用程序printf函数打印到终端上的信息,并写入日志? -
平皆甘油: linux 后台程序中printf占资源,printf函数在c语言中产生格式化输出的函数(定义在 stdio.h 中),其向终端(显示器、控制台等)输出字符.Linux是一套使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统.它能运行主要的UNIX工具、应用程序和网络协议.它支持32位和64位硬件.Linux继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统.

忻城县15672943436: 求LINUX下,C语言编写的日志输出源码~ -
平皆甘油: #include #include #include #include #define LOGFILE "./dir_log_0" int g_Count;//#define MAXLEN 1024 void WriteDebugLog(char *str); int main(int argc, char **argv) { char str[1024]={0}; strcpy(str,"file no find"); int i=0,j=0; for (i=0; i { for (j=0; ...

忻城县15672943436: 在linux下C语言写了一个while循环,怎么实现按任意键退出.如何编写程序? -
平皆甘油: char ch; while(1) {ch=kbhit(); } 按下任意键跳出死循环

忻城县15672943436: linux中用C语言编写完模块后怎么编写makefile文件 -
平皆甘油: 1、先写Makefile编译出***.ko文件 模板如下,保存到命名为Makefile文件里,放到你代码的同级目录下 TARGET=my_proc.ko LINUXDIR=/lib/modules/$(shell uname -r)/build PWD=$(shell pwd) obj-m := obj-m += my_proc.o all: $(TARGET)$(...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网