面试二十七、异步的日志

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日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

深度剖析SpringBoot日志性能提升的原因与解决

《深度剖析SpringBoot日志性能提升的原因与解决》日志记录本该是辅助工具,却为何成了性能瓶颈,SpringBoot如何用代码彻底破解日志导致的高延迟问题,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言第一章:日志性能陷阱的底层原理1.1 日志级别的“双刃剑”效应1.2 同步日志的“吞吐量杀手”

Python异步编程之await与asyncio基本用法详解

《Python异步编程之await与asyncio基本用法详解》在Python中,await和asyncio是异步编程的核心工具,用于高效处理I/O密集型任务(如网络请求、文件读写、数据库操作等),接... 目录一、核心概念二、使用场景三、基本用法1. 定义协程2. 运行协程3. 并发执行多个任务四、关键

java -jar example.jar 产生的日志输出到指定文件的方法

《java-jarexample.jar产生的日志输出到指定文件的方法》这篇文章给大家介绍java-jarexample.jar产生的日志输出到指定文件的方法,本文给大家介绍的非常详细,对大家的... 目录怎么让 Java -jar example.jar 产生的日志输出到指定文件一、方法1:使用重定向1、

C#异步编程ConfigureAwait的使用小结

《C#异步编程ConfigureAwait的使用小结》本文介绍了异步编程在GUI和服务器端应用的优势,详细的介绍了async和await的关键作用,通过实例解析了在UI线程正确使用await.Conf... 异步编程是并发的一种形式,它有两大好处:对于面向终端用户的GUI程序,提高了响应能力对于服务器端应

c++日志库log4cplus快速入门小结

《c++日志库log4cplus快速入门小结》文章浏览阅读1.1w次,点赞9次,收藏44次。本文介绍Log4cplus,一种适用于C++的线程安全日志记录API,提供灵活的日志管理和配置控制。文章涵盖... 目录简介日志等级配置文件使用关于初始化使用示例总结参考资料简介log4j 用于Java,log4c

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

nginx配置错误日志的实现步骤

《nginx配置错误日志的实现步骤》配置nginx代理过程中,如果出现错误,需要看日志,可以把nginx日志配置出来,以便快速定位日志问题,下面就来介绍一下nginx配置错误日志的实现步骤,感兴趣的可... 目录前言nginx配置错误日志总结前言在配置nginx代理过程中,如果出现错误,需要看日志,可以把

C# async await 异步编程实现机制详解

《C#asyncawait异步编程实现机制详解》async/await是C#5.0引入的语法糖,它基于**状态机(StateMachine)**模式实现,将异步方法转换为编译器生成的状态机类,本... 目录一、async/await 异步编程实现机制1.1 核心概念1.2 编译器转换过程1.3 关键组件解析

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用