C打印log日志的参考模板

mylog.h文件

#ifndef _MY_LOG_H_
#define _MY_LOG_H_

#define FILENAME	"./debug.log"

/*
#define IC_NO_LOG_LEVEL			0
#define IC_DEBUG_LEVEL			1
#define IC_INFO_LEVEL			2
#define IC_WARNING_LEVEL		3
#define IC_ERROR_LEVEL			4;
*/

/************************************************************************/
/* 
const char *file:文件名称,写:__FILE__
int line:文件行号,写:__LINE__
int level:错误级别
		0 -- 没有日志
		1 -- debug级别
		2 -- info级别
		3 -- warning级别
		4 -- err级别
int status:错误码
const char *fmt:可变参数
*/
/************************************************************************/
//实际使用的Level
extern int  LogLevel[5];
void MY_LOG(const char *file, int line, int level, int status, const char *fmt, ...);

#endif

mylog.c文件

#define  _CRT_SECURE_NO_WARNINGS 
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdarg.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <unistd.h>

#include "mylog.h"

#define MAX_STRING_LEN 		( (1024) * (10) )

//Level类别
#define IC_NO_LOG_LEVEL			0
#define IC_DEBUG_LEVEL			1
#define IC_INFO_LEVEL			2
#define IC_WARNING_LEVEL		3
#define IC_ERROR_LEVEL			4

int  LogLevel[5] = {IC_NO_LOG_LEVEL, IC_DEBUG_LEVEL, IC_INFO_LEVEL, IC_WARNING_LEVEL, IC_ERROR_LEVEL};

//Level的名称
char ICLevelName[5][10] = {"NOLOG", "DEBUG", "INFO", "WARNING", "ERROR"};

static int MY_Error_GetCurTime(char* strTime)
{
	struct tm*		tmTime  = NULL;
	size_t			timeLen = 0;
	time_t			tTime   = 0;	
	
	tTime = time(NULL);
	tmTime = localtime(&tTime);
	//timeLen = strftime(strTime, 33, "%Y(Y)%m(M)%d(D)%H(H)%M(M)%S(S)", tmTime);
	timeLen = strftime(strTime, 33, "%Y.%m.%d %H:%M:%S", tmTime);
	
	return timeLen;
}

static int MY_Error_OpenFile(int* pf)
{
	char	fileName[1024];
	
	memset(fileName, 0, sizeof(fileName));
#ifdef WIN32
	sprintf(fileName, "%s", FILENAME);
#else
	sprintf(fileName, "%s", FILENAME);
#endif
    
    *pf = open(fileName, O_WRONLY|O_CREAT|O_APPEND, 0666);

    if(*pf < 0)
    {
        return -1;
    }
	
	return 0;
}

static void MY_Error_Core(const char *file, int line, int level, int status, const char *fmt, va_list args)
{
    char str[MAX_STRING_LEN];
    int	 strLen = 0;
    char tmpStr[64];
    int	 tmpStrLen = 0;
    int  pf = 0;
    
    //初始化
    memset(str, 0, MAX_STRING_LEN);
    memset(tmpStr, 0, sizeof(tmpStr));
    
    //加入LOG时间
    tmpStrLen = MY_Error_GetCurTime(tmpStr);
    tmpStrLen = sprintf(str, "[%s] ", tmpStr);
    strLen = tmpStrLen;

    //加入LOG等级
    tmpStrLen = sprintf(str+strLen, "[%s] ", ICLevelName[level]);
    strLen += tmpStrLen;
    
    //加入LOG状态
    if (status != 0) 
    {
        tmpStrLen = sprintf(str+strLen, "[ERRNO is %d] ", status);
    }
    else
    {
    	tmpStrLen = sprintf(str+strLen, "[SUCCESS] ");
    }
    strLen += tmpStrLen;

    //加入LOG信息
    tmpStrLen = vsprintf(str+strLen, fmt, args);
    strLen += tmpStrLen;

    //加入LOG发生文件
    tmpStrLen = sprintf(str+strLen, " [%s]", file);
    strLen += tmpStrLen;

    //加入LOG发生行数
    tmpStrLen = sprintf(str+strLen, " [%d]\n", line);
    strLen += tmpStrLen;
    
    //打开LOG文件
    if(MY_Error_OpenFile(&pf))
	{
		return ;
	}
	
    //写入LOG文件
    write(pf, str, strLen);
    //IC_Log_Error_WriteFile(str);
    
    //关闭文件
    close(pf);
    
    return ;
}


void MY_LOG(const char *file, int line, int level, int status, const char *fmt, ...)
{
    va_list args;
	
	//判断是否需要写LOG
//	if(level!=IC_DEBUG_LEVEL && level!=IC_INFO_LEVEL && level!=IC_WARNING_LEVEL && level!=IC_ERROR_LEVEL)
	if(level == IC_NO_LOG_LEVEL)
	{
		return ;
	}
	
	//调用核心的写LOG函数
    va_start(args, fmt);
    MY_Error_Core(file, line, level, status, fmt, args);
    va_end(args);
    
    return ;
}


main.c 测试文件

#define  _CRT_SECURE_NO_WARNINGS 
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "mylog.h"

int main(void)
{
	//C语言自带宏
	// __FILE__: 左右两边都有2个下划线,当前__FILE__所在的文件, %s
	// __LINE__: 当前__LINE__所在的行, %d

//	printf("file = %s line = %d\n", __FILE__, __LINE__);

	int a = 10;
    
//    void MY_LOG(const char *file, int line, int level, int status, const char *fmt, ...);
	MY_LOG(__FILE__, __LINE__, 4, -100, "debug = %d\n", a);

	MY_LOG(__FILE__, __LINE__, 4, -1, "err = %d\n", 250);
	
	return 0;
}


测试结果

在这里插入图片描述

可以在该文件的基础上做修改,改成自己的log文件打印。

#include <stdio.h>
#include <unistd.h>
#include <stdarg.h>

#if 0
#define err_log(errmsg,ret) \
do{							\
	printf("----%s----%s----%d-----\n",__FILE__,__func__,__LINE__); \
	perror(errmsg);			\
	return ret;				\
}while(0)
#else
int err_log(int ret,char *format,...)
{
   va_list args;
   va_start(args, format);
   vprintf(format, args);
   va_end(args);
   return ret;
}
#endif

int main(int argc, char const *argv[])
{

//	err_log("hello world",0);
	err_log(0,"%d====hello world...\n",20);

	return 0;
}


在这里插入图片描述

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值