C++按模块名称选择性打印 cerr 流
C++ selective print of cerr stream by module names
假设我们在 20 个模块中有一个 30 K 行的代码数据库:即每个模块的每个 *.cpp 和 *.h 文件。在开发过程中,源代码是用局部变量通过 cerr 查找来修饰的。有时它具有与gdb相同的优势,有时则没有。人们希望保持 cerr 流的清洁/静音,并且只能从他希望的模块中获取对 cerr 的写入。我该如何 :
1)区分对cerr的写入,它们包含有关它们来自哪个模块的信息?2)为构建二进制文件添加cmd行选项,这将指定允许哪些模块写入cerr(我想看到的模块)。
编辑:事实上,最好的方法是使用日志记录框架(根据Joachim Pileborg的评论)。以下仅适用于您绝对必须坚持使用已有的代码,但想要将其整理干净的情况。
执行此操作的最佳方法是使用预处理器,使用 #ifdef
指令选择要生成的代码。
例如
#ifdef CERR_DEBUG_BUILD_MODULE_1
cout << __FILE__ << ":" << __LINE__ << "tCERR DEBUG OUTPUT" << endl;
#endif
该语句可能更好地包装在一个小宏中:
#ifdef CERR_DEBUG_BUILD_MODULE_1
#define LOG( x ) cerrLogPrint( x, __FILE__, __LINE__ )
#else
#define LOG( x )
#endif
哪里
void cerrLogPrint( const char* const log, const char* filename, unsigned int line)
{
//PRINT
}
相关文章:
- 如何循环打印顶点结构
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 如何在c++中打印目录
- 有一个打印语句的函数是一种糟糕的编程实践吗
- 在线编译器中的分段C++没有打印消息
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 如何将结构插入到集合中并打印集合的成员
- 在循环C++中指定字符串之后,不会打印该字符串
- 以螺旋方式打印矩阵的程序.(工作不好)
- 从控制台中删除最后打印的元素
- 如何使用Crypto++并为RSA返回可打印的字节/字符数组
- 如何仅使用对象名称打印特定于对象的成员
- 回溯C++不打印函数,因此文件
- 在一定长度后从数组中打印时缺少整数
- 为什么这个 c++ 代码打印出长度 5,当我打印出字符串时,程序会自动终止?
- 在gem5中打印文件中的所有cache_blocks
- 为什么在打印东西时没有保留顺序,先用cerr,然后用cout
- C++按模块名称选择性打印 cerr 流
- 如何在c++中在cout/cerr上打印USB字符串描述符