用C实现日志文件的记录

 

#include <stdio.h>
#include <time.h>
#include <string.h>
#include <errno.h>

/*宏定义参数*/
#define RecordLogFile(ONE, TWO)  defineRecordLogFile(__FILE__, __LINE__, ONE, TWO)

int defineRecordLogFile(char *pszMyFileName, int iLine,\
                        char *pszMyErroe, const char *pszLogFileName);

int main(int argc, char *argv[])
{
    if (argc < 2)
    {
        RecordLogFile("我自己的输出错误!", "liujie.log");
        return 1;
    }
    return 0;
}

int defineRecordLogFile(char *pszMyFileName, int iLine,\
                        char *pszMyError, const char *pszLogFileName)
{
    FILE *fpLogFile;
    time_t timeTemp;
    struct tm *pstTime;
    pid_t pidMyId;
  
    char szNewLogFileName[64 + 1];
    char szSystem[128 + 1];
    char szTime[19 + 1];
 
    /*打开文件*/
    if ((fpLogFile = fopen(pszLogFileName, "a")) == NULL)
    {
        printf("open LogFile faile!");
        RecordLogFile("open LogFile faile!", "liujie.log");
        return 1;
    }

    /*时间*/
    timeTemp = time(NULL);
    pstTime = localtime(&timeTemp);

    sprintf(szTime, "%2.2d-%2.2d-%2.2d-%2.2d:%2.2d:%2.2d ",\
            pstTime->tm_year + 1900,pstTime->tm_mon + 1,\
            pstTime->tm_mday,pstTime->tm_hour,pstTime->tm_min,\
            pstTime->tm_sec);

    fprintf(fpLogFile, szTime);
   
    /*得到文件ID*/
    pidMyId = getpid();
    fprintf(fpLogFile, "pid = %d ", pidMyId);

    /*得到文件位置*/
    fprintf(fpLogFile, "%s:%d ", pszMyFileName, iLine);

    /*得到错误信息*/
    fprintf(fpLogFile, "useerror: %s ", pszMyError);
    fprintf(fpLogFile, "error: %s\n", strerror(errno));
   
    /*关闭文件*/
    fclose(fpLogFile);
  
    /*调用system实现拷贝*/
    memset(szSystem, 0, 128 + 1);
    memset(szNewLogFileName, 0, 64 + 1);
    /*得到新配置文件名*/
    strncpy(szNewLogFileName, pszLogFileName, 64 - 19);
    strncat(szNewLogFileName, szTime, 19);
    /*得到system参数*/
    strncpy(szSystem, "cp ", 3);
    strncat(szSystem, pszLogFileName, 64);
    strncat(szSystem, " ", 1);
    strncat(szSystem, szNewLogFileName, 64);

    system(szSystem);
    return 0;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值