Linux C语言自己动手写日志生成函数

        有时候需要自己把日志信息保存到日志文件中,没有找到现成的函数,只好自己动手写一个,完成相关功能。

 

void LOG(const char* ms, ... )
{
	char wzLog[1024] = {0};
	char buffer[1024] = {0};
	va_list args;
	va_start(args, ms);
	vsprintf( wzLog ,ms,args);
	va_end(args);

	time_t now;
	time(&now);
	struct tm *local;
	local = localtime(&now);
	printf("%04d-%02d-%02d %02d:%02d:%02d %s\n", local->tm_year+1900, local->tm_mon,
			local->tm_mday, local->tm_hour, local->tm_min, local->tm_sec,
			wzLog);
	sprintf(buffer,"%04d-%02d-%02d %02d:%02d:%02d %s\n", local->tm_year+1900, local->tm_mon,
				local->tm_mday, local->tm_hour, local->tm_min, local->tm_sec,
				wzLog);
	FILE* file = fopen("testResut.log","a+");
	fwrite(buffer,1,strlen(buffer),file);
	fclose(file);

//	syslog(LOG_INFO,wzLog);
	return ;
}


 

可能用到的头文件

#include <time.h>

#include <stdarg.h>

#include <syslog.h>

你可能感兴趣的:(Linux C语言自己动手写日志生成函数)