0

0

C++日志文件记录 时间戳分级写入方法

P粉602998670

P粉602998670

发布时间:2025-09-02 09:00:01

|

662人浏览过

|

来源于php中文网

原创

答案是使用spdlog库实现高效日志记录,包含时间、级别、内容等要素,并支持格式定制与文件切割。首先选择高性能、功能丰富的spdlog库;其次定义TRACE、DEBUG、INFO、WARNING、ERROR、CRITICAL等日志级别;然后通过set_pattern设置包含时间戳、级别、文件名、行号和消息内容的可读格式;最后利用rotating_file_sink实现基于大小的自动切割与归档,或daily_file_sink按时间分割,确保日志可控且便于排查问题。

c++日志文件记录 时间戳分级写入方法

C++记录日志文件,核心在于时间、级别、内容,然后写入文件。看似简单,但做好却有不少细节。

解决方案

首先,需要选择一个合适的日志库。如果不想引入第三方库,完全可以自己实现一个简单的日志系统。不过,为了效率和功能性,推荐使用现成的库,比如spdlog,fmtlog,glog等。这里以spdlog为例,因为它速度快,使用方便,而且支持多种格式化方式。

其次,确定日志级别。通常包括TRACE, DEBUG, INFO, WARNING, ERROR, CRITICAL。根据实际情况选择合适的级别,方便调试和问题追踪。

立即学习C++免费学习笔记(深入)”;

再者,设计日志格式。一个好的日志格式应该包含时间戳、日志级别、文件名、行号、以及具体的消息内容。这样在排查问题时,可以快速定位到代码位置。

最后,实现日志写入功能。可以将日志写入到控制台、文件,甚至网络。写入文件时,需要考虑文件大小、切割策略等问题,避免日志文件过大。

如何选择合适的C++日志库?

选择日志库,需要考虑几个关键点:性能、功能、易用性。spdlog在性能上表现出色,而且功能丰富,支持异步日志、多线程安全、自定义格式等。fmtlog也很快,但功能相对简单。glog是Google开源的日志库,功能强大,但配置相对复杂。

如果项目对性能要求较高,可以选择spdlog或fmtlog。如果需要更丰富的功能,或者对Google的库比较熟悉,可以选择glog。另外,还需要考虑库的维护情况,选择活跃的、有社区支持的库,可以避免遇到问题时无人解答。

亿众购物系统
亿众购物系统

一套设计完善、高效的web商城解决方案,独有SQL注入防范、对非法操作者锁定IP及记录功能,完整详细的记录了非法操作情况,管理员可以随时查看网站安全日志以及解除系统自动锁定的IP等前台简介:  1)系统为会员制购物,无限会员级别。  2)会员自动升级、相应级别所享有的折扣不同。  3)产品可在缺货时自动隐藏。  4)自动统计所有分类中商品数量,并在商品分类后面显示。  5)邮件列表功能,可在线订阅

下载

如何自定义C++日志格式,使其更易于阅读和分析?

自定义日志格式,关键在于使用格式化字符串。spdlog使用fmtlib的格式化语法,非常灵活。例如,可以这样定义日志格式:

#include 
#include  // support for basic file logging

int main() {
  try {
    auto my_logger = spdlog::basic_logger_mt("basic_logger", "logs/basic-log.txt");
    spdlog::set_default_logger(my_logger);
    spdlog::set_pattern("[%Y-%m-%d %H:%M:%S.%e] [%l] [%s:%#] %v");
    spdlog::info("This is an info message");
    spdlog::error("This is an error message with custom format");
  }
  catch (const spdlog::spdlog_ex& ex) {
    std::cout << "Log init failed: " << ex.what() << std::endl;
  }
}

上面的代码定义了一个包含时间戳、日志级别、文件名和行号的日志格式。其中:

  • %Y-%m-%d %H:%M:%S.%e
    表示日期和时间,精确到毫秒。
  • %l
    表示日志级别。
  • %s
    表示文件名。
  • %#
    表示行号。
  • %v
    表示消息内容。

可以根据自己的需求调整格式化字符串,添加或删除字段。例如,如果不需要文件名和行号,可以将其删除。如果需要线程ID,可以添加

%t

如何实现C++日志文件的自动切割和归档?

日志文件自动切割和归档,是为了防止单个日志文件过大,影响性能和存储。spdlog提供了多种切割策略,比如基于文件大小的切割、基于时间的切割。

基于文件大小的切割,可以使用

rotating_file_sink

#include 
#include 

int main() {
  try {
    auto rotating_logger = spdlog::rotating_logger_mt("rotating_logger", "logs/rotating.txt", 1024 * 1024 * 5, 3); // 5MB max size, 3 rotated files
    spdlog::set_default_logger(rotating_logger);
    spdlog::info("This is a rotating log message");
    for (int i = 0; i < 1000000; ++i) {
      spdlog::info("Loop {}", i);
    }
  }
  catch (const spdlog::spdlog_ex& ex) {
    std::cout << "Log init failed: " << ex.what() << std::endl;
  }
}

上面的代码创建了一个

rotating_file_sink
,指定了日志文件的最大大小为5MB,最多保留3个归档文件。当日志文件达到5MB时,会自动创建一个新的日志文件,并将旧的日志文件重命名为
rotating.txt.1
,以此类推。

基于时间的切割,可以使用

daily_file_sink
。不过,需要自己实现归档功能,比如每天凌晨将旧的日志文件移动到归档目录。

选择哪种切割策略,取决于实际需求。如果对文件大小比较敏感,可以选择基于文件大小的切割。如果需要按时间归档,可以选择基于时间的切割。

相关专题

更多
scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

188

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

291

2023.10.25

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

278

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1492

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

622

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

572

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

566

2024.04.29

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 7.4万人学习

C 教程
C 教程

共75课时 | 4.2万人学习

C++教程
C++教程

共115课时 | 13.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号