C/C++预定义宏与调试日志输出模板

前言: 在个人的上一篇博客C/C++常见的预定义宏与基本使用方法-CSDN博客中对C/C++预定义宏的定义、常见的预定义宏及其用法做了初步的介绍,并可以了解到预定义宏可以用于C/C++程序的调试日志输出,本文基于预定义宏与调试日志输出需要出发定义调试日志输出宏模板,以用于程序开发者对程序错误的定位与运行日志的记录等。

调试与日志宏模板定义:

1、调试输出宏模板

cpp 复制代码
#include <iostream>

#ifdef _DEBUG
#define LOG_DEBUG(msg) \
std::cout << "[DEBUG] " << __FILE__ << ":" << __LINE__ << " (" << __FUNCTION__ << ") - " << msg << std::endl;
#else
#define LOG_DEBUG(msg)
#endif

调试输出样例

cpp 复制代码
LOG_DEBUG("This is debug output!")

[DEBUG] main.cpp:13 (main) This is debug output!

2、带有详细时间戳的调试输出宏模板

cpp 复制代码
#include <iostream>
#include <chrono>
#include <iomanip>

#ifdef _DEBUG
#define LOG_DEBUG(msg) { \
    std::time_t now = std::time(nullptr);
    std::tm* local_time = std::localtime(&now);
    std::cout << "[" << std::put_time(&tm, "%Y-%m-%d %H:%M:%S") << "] " \
              << "[DEBUG] " << __FILE__ << ":" << __LINE__ \
              << " (" << __FUNCTION__ << ") - " \
              << msg << std::endl; \
}
#else
#define LOG_DEBUG(msg)
#endif

调试输出样例:

cpp 复制代码
LOG_DEBUG("This is debug output!")

[2025-09-29 10:32:16][DEBUG] main.cpp:13 (main) - This is debug output!

3、文件日志输出模板

cpp 复制代码
#include <iostream>
#include <fstream>

// 模板主动缺省输出路径log_output_path,直接使用报错,以提醒使用时指定特定的日志输出路径
#define LOG_TO_FILE(msg) { \
    std::string log_output_path = ; \
    std::ofstream logFile(log_output_path, std::ios::app); \
    logFile << "[INFO] " << __FILE__ << ":" << __LINE__ << " (" << __FUNCTION__ << ") - " << msg << std::endl; \
}

文件日志输出样例:

cpp 复制代码
#include <iostream>
#include <fstream>

// 模板主动缺省输出路径log_output_path,直接使用报错,以提醒使用时指定特定的日志输出路径
#define LOG_TO_FILE(msg) { \
    // 此处使用是指定输出路径为"/home/user/temp/log.txt"
    std::string log_output_path = "/home/user/temp/log.txt"; \
    std::ofstream logFile(log_output_path, std::ios::app); \
    logFile << "[INFO] " << __FILE__ << ":" << __LINE__ << " (" << __FUNCTION__ << ") - " << msg << std::endl; \
}

LOG_TO_FILE("This is a log info!")

[INFO] main.cpp:14 (main) - This is a log info!

4、带有时间戳的文件日志输出模板

cpp 复制代码
#include <iostream>
#include <fstream>

// 模板主动缺省输出路径log_output_path,直接使用报错,以提醒使用时指定特定的日志输出路径
#define LOG_TO_FILE(msg) { \
    std::string log_output_path = ; \
    std::ofstream logFile(log_output_path, std::ios::app); \
    std::time_t now = std::time(nullptr);
    std::tm* local_time = std::localtime(&now);
    logFile << "[" << std::put_time(&tm, "%Y-%m-%d %H:%M:%S") << "] " \
            << "[INFO] " << __FILE__ << ":" << __LINE__ << " (" << __FUNCTION__ << ") - " \
            << msg << std::endl; \
}

文件日志输出样例:

cpp 复制代码
#include <iostream>
#include <fstream>

// 模板主动缺省输出路径log_output_path,直接使用报错,以提醒使用时指定特定的日志输出路径
#define LOG_TO_FILE(msg) { \
    // 此处使用是指定输出路径为"/home/user/temp/log.txt"
    std::string log_output_path = "/home/user/temp/log.txt"; \
    std::ofstream logFile(log_output_path, std::ios::app); \
    std::time_t now = std::time(nullptr);
    std::tm* local_time = std::localtime(&now);
    logFile << "[" << std::put_time(&tm, "%Y-%m-%d %H:%M:%S") << "] " \
            << "[INFO] " << __FILE__ << ":" << __LINE__ << " (" << __FUNCTION__ << ") - " \
            << msg << std::endl; \
}

LOG_TO_FILE("This is a log info!")

[2025-09-29 10:41:45][INFO] main.cpp:14 (main) - This is a log info!

参考博客:在 C++ 中实现调试日志输出_c++输出调试信息-CSDN博客

相关推荐
Cloud_Shy6189 小时前
解读《Effective Python 3rd Edition》:从练气到老魔(第五章 Item 33 - 35)
开发语言·人工智能·笔记·python·学习方法
星恒随风9 小时前
C++ 类和对象入门(五):初始化列表、explicit 和 static 成员详解
开发语言·c++·笔记·学习·状态模式
艾利克斯冰9 小时前
Java 设计模式-行为型模式(更新中)
java·开发语言·设计模式
倒霉蛋小马9 小时前
Java新特性:record关键字
java·开发语言
浪客灿心10 小时前
项目篇:模块设计与实现
数据库·c++
budingxiaomoli10 小时前
Spring日志
java·开发语言
牛油果子哥q10 小时前
【C++ STL vector】C++ STL vector 终极精讲:动态数组底层原理、两倍扩容机制、迭代器失效、增删查改、性能剖析与工程避坑指南
开发语言·c++
贩卖黄昏的熊10 小时前
flex 布局快速梳理
开发语言·javascript·css3·html5
天天进步201510 小时前
Python全栈项目--校园智能宿舍管理系统
开发语言·python
CodeStats10 小时前
从 CPU 指令到 JVM 进程:彻底讲透 Java 执行 main 方法时,类加载、主线程、栈帧入栈的完整底层逻辑
java·linux·开发语言