#define函数的多个定义
multiple definition of #define function
我有logger.h文件,并定义了一个用于日志记录的宏函数:
//logger.h:
#ifndef _LOGGER_H_
#define _LOGGER_H_
#ifdef LOG_DEBUG
ofstream debug_log("debug.log");
#define log(...) debug_log << __FILE__ << ":" << __PRETTY_FUNCTION__ << ":" << __LINE__ << "| " << __VA_ARGS__ << std::endl
#else
#define log(...)
#endif
#endif
这个头文件包含在多个c文件中。并使用log()函数。g++给出:
/tmp/ccMAjYSm.o:(.bss+0x0): multiple definition of `debug_log'
/tmp/ccHj3w7u.o:(.bss+0x0): first defined here
/tmp/cc3LQ9GQ.o:(.bss+0x0): multiple definition of `debug_log'
/tmp/ccHj3w7u.o:(.bss+0x0): first defined here
什么线索吗?
如果您在项目级别(或在多个翻译单元中)声明LOG_DEBUG
,他们都将看到
ofstream debug_log("debug.log");
行,你将有多个定义。
一个可能的解决方案:把它放在一个单独的翻译单元中,同时让所有其他人都知道它的存在
头
#ifndef _LOGGER_H_
#define _LOGGER_H_
#ifdef LOG_DEBUG
extern ofstream debug_log;
#define log(...) debug_log << __FILE__ << ":" << __PRETTY_FUNCTION__ << ":" << __LINE__ << "| " << __VA_ARGS__ << std::endl
#else
#define log(...)
#endif
#endif
cpp文件
ofstream debug_log("debug.log");
最终#include
的log .h的每个源文件将看到以下内容:
ofstream debug_log("debug.log");
,然后创建该对象。现在你有多个对象命名为debug_log
。
在这里向前声明对象,但将实例化放在.cpp文件中。
相关文章:
- 在命名空间中定义函数还是限定函数
- 为什么在定义函数之前先声明它
- 使用用户定义函数的字符串反转
- 用户定义函数中的指针和输入
- 这个c++代码是如何在没有定义函数的情况下运行的
- 具有外部"c"和程序集的未定义函数
- 已定义函数时出现 G++ "未定义的引用"错误
- 将自定义函数传递到基抽象类中以延迟执行
- C++使用 rand 定义函数语法
- Arduino:在 loop() 和自定义函数中运行相同的代码时出现问题
- 将具有固定签名的自定义函数名称注入 CRTP
- 使用定义函数模板别名
- 是否可以使用单个定义定义函数的常量和常规版本?(使用模板,自动,decltype等)
- 在内联程序集中定义函数和从 C++ 调用时出现问题
- 在 Metal 着色器代码中,如何定义函数的 in/out 参数变量?
- 声明和定义函数静态会产生"undefined reference to function_name()"
- 朋友定义函数的名称空间是什么
- 介子 对用户定义函数的未定义引用
- 如何使用 "using" 关键字定义函数原型/签名
- 在 C 结构中定义C++函数