面试二十七、异步的日志

2024-05-31 17:04
文章标签 面试 日志 异步 二十七

本文主要是介绍面试二十七、异步的日志,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        日志消息的写入操作在一个独立的线程中进行,而不是在调用log函数的主线程中进行。这意味着主线程可以继续执行其他任务,而不需要等待日志消息写入完成。这提高了程序的性能和响应速度,特别是在日志写入操作耗时较长的情况下。

#include <iostream>
#include <fstream>
#include <string>
#include <thread>
#include <mutex>
#include <condition_variable>
#include <queue>
#include <atomic>class AsyncLogger {
public:AsyncLogger(const std::string& filename) : logFile(filename, std::ios::out | std::ios::app), isRunning(true), logThread(&AsyncLogger::processLogs, this) {if (!logFile.is_open()) {throw std::runtime_error("Failed to open log file.");}}~AsyncLogger() {{std::unique_lock<std::mutex> lock(mutex);isRunning = false;condVar.notify_all();}logThread.join();}void log(const std::string& message) {std::unique_lock<std::mutex> lock(mutex);logQueue.push(message);condVar.notify_all();}private:void processLogs() {while (isRunning || !logQueue.empty()) {std::unique_lock<std::mutex> lock(mutex);condVar.wait(lock, [this]() { return !logQueue.empty() || !isRunning; });while (!logQueue.empty()) {logFile << logQueue.front() << std::endl;logQueue.pop();}}}std::ofstream logFile;std::atomic<bool> isRunning;std::thread logThread;std::queue<std::string> logQueue;std::mutex mutex;std::condition_variable condVar;
};int main() {try {AsyncLogger logger("async_log.txt");logger.log("Log message 1");logger.log("Log message 2");logger.log("Log message 3");std::this_thread::sleep_for(std::chrono::seconds(1)); // 模拟其他工作logger.log("Log message 4");// 等待一段时间以确保所有日志都被处理std::this_thread::sleep_for(std::chrono::seconds(2));} catch (const std::exception& e) {std::cerr << "Exception: " << e.what() << std::endl;}return 0;
}

代码解释

  1. AsyncLogger类:管理异步日志记录功能。

    • logFile:日志文件流,用于写入日志消息。
    • isRunning:标志异步日志线程是否运行。
    • logThread:处理日志消息的线程。
    • logQueue:存储待写入的日志消息。
    • mutex:保护共享数据的互斥量。
    • condVar:条件变量,用于线程间通信。
  2. 构造函数和析构函数

    • 构造函数打开日志文件并启动日志线程。
    • 析构函数关闭日志线程并确保所有日志消息都被处理。
  3. log函数:将日志消息添加到队列中,并通知日志线程有新消息需要处理。

  4. processLogs函数:日志线程运行的函数,不断从队列中取出日志消息并写入日志文件。

进一步改进

  1. 添加日志级别(例如INFO, WARN, ERROR)。
  2. 处理日志写入失败的情况。
  3. 实现一个线程安全的队列来提高代码的健壮性。

a. 添加日志级别支持,例如INFO、WARN、ERROR。
b. 改进日志系统以处理日志文件写入失败的情况

这篇关于面试二十七、异步的日志的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1018524

相关文章

SpringBoot日志配置SLF4J和Logback的方法实现

《SpringBoot日志配置SLF4J和Logback的方法实现》日志记录是不可或缺的一部分,本文主要介绍了SpringBoot日志配置SLF4J和Logback的方法实现,文中通过示例代码介绍的非... 目录一、前言二、案例一:初识日志三、案例二:使用Lombok输出日志四、案例三:配置Logback一

golang 日志log与logrus示例详解

《golang日志log与logrus示例详解》log是Go语言标准库中一个简单的日志库,本文给大家介绍golang日志log与logrus示例详解,感兴趣的朋友一起看看吧... 目录一、Go 标准库 log 详解1. 功能特点2. 常用函数3. 示例代码4. 优势和局限二、第三方库 logrus 详解1.

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

如何自定义Nginx JSON日志格式配置

《如何自定义NginxJSON日志格式配置》Nginx作为最流行的Web服务器之一,其灵活的日志配置能力允许我们根据需求定制日志格式,本文将详细介绍如何配置Nginx以JSON格式记录访问日志,这种... 目录前言为什么选择jsON格式日志?配置步骤详解1. 安装Nginx服务2. 自定义JSON日志格式各

Java 中实现异步的多种方式

《Java中实现异步的多种方式》文章介绍了Java中实现异步处理的几种常见方式,每种方式都有其特点和适用场景,通过选择合适的异步处理方式,可以提高程序的性能和可维护性,感兴趣的朋友一起看看吧... 目录1. 线程池(ExecutorService)2. CompletableFuture3. ForkJoi

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

SpringBoot项目使用MDC给日志增加唯一标识的实现步骤

《SpringBoot项目使用MDC给日志增加唯一标识的实现步骤》本文介绍了如何在SpringBoot项目中使用MDC(MappedDiagnosticContext)为日志增加唯一标识,以便于日... 目录【Java】SpringBoot项目使用MDC给日志增加唯一标识,方便日志追踪1.日志效果2.实现步

SQL Server清除日志文件ERRORLOG和删除tempdb.mdf

《SQLServer清除日志文件ERRORLOG和删除tempdb.mdf》数据库再使用一段时间后,日志文件会增大,特别是在磁盘容量不足的情况下,更是需要缩减,以下为缩减方法:如果可以停止SQLSe... 目录缩减 ERRORLOG 文件(停止服务后)停止 SQL Server 服务:找到错误日志文件:删除

grom设置全局日志实现执行并打印sql语句

《grom设置全局日志实现执行并打印sql语句》本文主要介绍了grom设置全局日志实现执行并打印sql语句,包括设置日志级别、实现自定义Logger接口以及如何使用GORM的默认logger,通过这些... 目录gorm中的自定义日志gorm中日志的其他操作日志级别Debug自定义 Loggergorm中的

Spring Boot 中正确地在异步线程中使用 HttpServletRequest的方法

《SpringBoot中正确地在异步线程中使用HttpServletRequest的方法》文章讨论了在SpringBoot中如何在异步线程中正确使用HttpServletRequest的问题,... 目录前言一、问题的来源:为什么异步线程中无法访问 HttpServletRequest?1. 请求上下文与线