一个简单可用的C++日志类

本文介绍了一个简单的C++日志记录类的实现过程,包括类的设计、关键代码解析及一个示例程序。该日志类能够将带有时间戳的日志信息追加到指定文件中。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

少废话,直接看东西。

//LogWriter.h
#pragma once
#include <stdio.h>

#define LOG_BUFFER_SIZE 1024
class LogWriter
{
public:
    LogWriter(const char * filepath);
    ~LogWriter(void);
    bool write(const char * format, ...);
private:
    static int preMark(char * buffer);
private:
    FILE * fp;
    char   m_buffer[LOG_BUFFER_SIZE];
};
//LogWriter.cpp
#include "LogWriter.h"
#include <assert.h>
#include <share.h>
#include <stdarg.h>
#include <time.h>

LogWriter::LogWriter(const char * filepath)
{
    fp = _fsopen(filepath, "a+", _SH_DENYNO);
    assert(fp != NULL);
}

LogWriter::~LogWriter(void)
{
    if (fp) {
        fclose(fp);
        fp = NULL;
    }
}

bool LogWriter::write(const char * format, ...)
{
    if (fp == NULL)
        return false;

    int nsize = 0;
    int prelen = 0;
    char * str = m_buffer;
    prelen = preMark(str);
    str += prelen;

    va_list args;
    va_start(args, format);
    nsize = _vsnprintf(str, LOG_BUFFER_SIZE - prelen, format, args);
    va_end(args);

    fprintf(fp, "%s\n", m_buffer);
    fflush(fp);
    return true;
}

int LogWriter::preMark(char * buffer)
{
    time_t now;
    now = time(&now);
    struct tm vtm = *localtime(&now);
    return _snprintf(buffer, LOG_BUFFER_SIZE, "%04d-%02d-%02d %02d:%02d:%02d ",
        vtm.tm_year+1900, vtm.tm_mon, vtm.tm_mday, vtm.tm_hour, vtm.tm_min, vtm.tm_sec);
}

测试程序:

//main.cpp
#include "LogWriter.h"

int main()
{
    LogWriter log("D:\\app.log");
    log.write("%s, %d", "hello", 123);
}

看效果:
这里写图片描述

PS:
程序可以改进的地方还有很多,但是已经可以用了,在一般的程序里面运行不会有问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值