legongju.com
我们一直在努力
2025-01-16 00:02 | 星期四

C++ logger的异步日志记录

在C++中实现异步日志记录通常使用多线程来实现。以下是一个简单的示例代码:

#include 
#include 
#include 
#include 
#include 
#include 
#include 

class Logger {
public:
    Logger() : isRunning(true) {
        outputFile.open("log.txt", std::ios::app);
        workerThread = std::thread(&Logger::logWorker, this);
    }

    ~Logger() {
        isRunning = false;
        workerThread.join();
        outputFile.close();
    }

    void log(const std::string& message) {
        std::lock_guard lock(mutex);
        logQueue.push(message);
        cv.notify_one();
    }

private:
    std::ofstream outputFile;
    std::queue logQueue;
    std::mutex mutex;
    std::condition_variable cv;
    bool isRunning;
    std::thread workerThread;

    void logWorker() {
        while (isRunning) {
            std::unique_lock lock(mutex);
            cv.wait(lock, [this] { return !logQueue.empty() || !isRunning; });

            while (!logQueue.empty()) {
                std::string message = logQueue.front();
                logQueue.pop();
                outputFile << message << std::endl;
            }
        }
    }
};

int main() {
    Logger logger;

    logger.log("Hello, World!");
    logger.log("This is a log message.");

    return 0;
}

在上面的示例中,Logger类包含一个日志队列logQueue,一个互斥锁mutex和一个条件变量cv。日志消息通过log()方法添加到队列中,在logWorker()方法中的工作线程中从队列中取出消息,并将其写入日志文件中。当程序结束时,Logger类的析构函数会关闭日志文件并等待工作线程结束。

在主函数中,创建一个Logger实例,并使用log()方法记录日志消息。由于日志记录是在后台线程中进行的,不会阻塞主线程。

未经允许不得转载 » 本文链接:https://www.legongju.com/article/110906.html

相关推荐

  • c++ mysql库的数据更新与删除操作

    c++ mysql库的数据更新与删除操作

    在C++中,可以使用MySQL C++ Connector库来进行数据更新和删除操作。以下是一个简单的示例代码,展示如何使用MySQL C++ Connector库来进行数据更新和删除操作:<...

  • c++ memset_s与memset有何不同

    c++ memset_s与memset有何不同

    memset_s 和 memset 都是 C++ 中用于设置内存区域的函数,但它们之间存在一些关键差异 安全性:memset_s 是一个更安全的版本,因为它会检查目标缓冲区的大小。如...

  • c++中使用memset_s需要注意什么

    c++中使用memset_s需要注意什么

    在C++中,memset_s函数是一个安全的内存设置函数,它可以防止缓冲区溢出 包含头文件:在使用memset_s之前,请确保已经包含了正确的头文件。对于C++,应该包含头文...

  • c++ memset_s如何安全清零内存

    c++ memset_s如何安全清零内存

    在C++中,memset_s是一个安全的方法来清零内存
    #include
    #include int main() { char buffer[100]; // 填充缓冲区 for (int i = 0; i< sizeof(buffer)...

  • C++ signed与模板编程

    C++ signed与模板编程

    在C++中,signed是一个关键字,用来表示有符号的数据类型。例如,signed int表示有符号的整型数据类型。
    模板编程是一种编程技术,允许程序员编写通用的代码...

  • C++ signed与函数参数

    C++ signed与函数参数

    在C++中,signed是一种数据类型修饰符,表示该数据类型是有符号的。通常情况下,整数类型默认是有符号的,即可以表示正数、负数和零。如果使用signed修饰整数类型...

  • C++ signed与数组索引

    C++ signed与数组索引

    在C++中,signed是一种修饰符,用来表示有符号类型。当用signed修饰int时,int会被解释为有符号整数类型。通常情况下,int默认是有符号类型,所以signed修饰符通...

  • C++ signed与位运算

    C++ signed与位运算

    在C++中,signed修饰符用于指定整数类型为有符号整数,即可以表示正数、负数和零。
    位运算是一种对整数按位进行操作的运算,包括与(&)、或(|)、异或(^...