如何避免PANTHEIOS_FE_PROCESS_IDENTITY的多重定义
How to avoid multiple definition of PANTHEIOS_FE_PROCESS_IDENTITY?
我正在处理一个有多个文件的项目,我需要登录每个文件。
为了编译一个文件,我需要以下内容:
/* Define the stock front-end process identity, so that it links when using
* fe.N, fe.simple, etc. */
PANTHEIOS_EXTERN_C const PAN_CHAR_T PANTHEIOS_FE_PROCESS_IDENTITY[] = PSTR("fileX.cpp");
比方说,我有两个文件共有的log1.cpp、log2.cpp和log.h。这些文件被编译为log1.o和log2.o。这很好。
现在,当我将这两个文件链接到一个可执行文件中时,我会得到以下错误:
log2.o:(.rodata+0x11): multiple definition of `PANTHEIOS_FE_PROCESS_IDENTITY'
log1.o:(.rodata+0x45): first defined here
现在的问题是,需要在file1.cpp和file2.cpp中定义PANTHEIOS_FE_PROCESS_IDENTITY才能进行编译。
我需要如何更改代码才能将其链接到可执行文件中?
以下是使用的文件:log1.cpp:
#include "log.h"
const PAN_CHAR_T PANTHEIOS_FE_PROCESS_IDENTITY[] = PSTR("log1.cpp");
int main()
{
PANTHEIOS_TRACE_NOTICE(PSTR("a string at NOTICE level"));
return 0;
}
log2.cpp:
#include "log.h"
const PAN_CHAR_T PANTHEIOS_FE_PROCESS_IDENTITY[] = PSTR("log1.cpp");
log.h:
#ifndef LOG_H
#define LOG_H
/* Pantheios Header Files */
#include <pantheios/pantheios.h> // Pantheios C main header
#ifndef STLSOFT_CF_SUPPORTS_VARIADIC_MACROS
# error This example uses the Tracing API, which requires that the compiler support variadic macros
#endif /* !STLSOFT_CF_SUPPORTS_VARIADIC_MACROS */
#ifdef STLSOFT_CF_FUNCTION_SYMBOL_SUPPORT
# include <string>
# define PANTHEIOS_TRACE_PREFIX
( std::basic_string< PANTHEIOS_NS_QUAL(pan_char_t)>(__FILE__ " " PANTHEIOS_STRINGIZE(__LINE__) ": ") +
__FUNCTION__ +
"(): "
).c_str()
#endif /* STLSOFT_CF_FUNCTION_SYMBOL_SUPPORT */
#include <pantheios/trace.h> // Pantheios Trace API
#include <pantheios/pantheios.hpp> // Pantheios C++ main header
/* Standard C/C++ Header Files */
#include <exception> // for std::exception
#include <new> // for std::bad_alloc
#include <string> // for std::string
#include <stdlib.h> // for exit codes
#ifndef PANTHEIOS_DOCUMENTATION_SKIP_SECTION
# if defined(STLSOFT_COMPILER_IS_MSVC)
# pragma warning(disable : 4702)
# endif /* compiler */
#endif /* !PANTHEIOS_DOCUMENTATION_SKIP_SECTION */
#define PSTR(x) PANTHEIOS_LITERAL_STRING(x)
#include "pantheios/frontends/fe.simple.h" //for pantheios_fe_simple_setSeverityCeiling(level);
#endif //LOG_H
以及make的输出:
g++ log1.cpp -c -I../pantheios-1.0.1-beta213/include -I../stlsoft-1.9.112/include
g++ log2.cpp -c -I../pantheios-1.0.1-beta213/include -I../stlsoft-1.9.112/include
g++ -o log log1.o log2.o -L../pantheios-1.0.1-beta213/lib
-lpantheios.1.core.gcc44
-lpantheios.1.be.fprintf.gcc44 -lpantheios.1.bec.fprintf.gcc44
-lpantheios.1.fe.simple.gcc44 -lpantheios.1.util.gcc44
log2.o:(.rodata+0x0): multiple definition of `PANTHEIOS_FE_PROCESS_IDENTITY'
log1.o:(.rodata+0x1): first defined here
/usr/bin/ld: Warning: size of symbol `PANTHEIOS_FE_PROCESS_IDENTITY' changed from 14 in log1.o to 9 in log2.o
collect2: ld returned 1 exit status
编辑:在pantheios-10.1-beta213/include/panetios/frontends/stock.h:120中,"pantheios_FE_PROCESS_IDENTITY"被声明为extern,所以我不能将其重新定义为static。
如果我的问题/答案听起来很奇怪,我深表歉意:但为什么要在每个.cpp文件中定义PANTHEIOS_FE_PROCESS_IDENTITY?PANTHEIOS_FE_PROCESS_IDENTITY在每个日志记录过程中只需要定义一次,并在每行的开头打印到日志语句中。例如,来自我自己的基于pantheios的记录器项目:
[l.SP.64082012年4月7日下午6:28:44.702;通知]:。\Log.cpp(168):CLogApp::InitInstance:STARTING LOGING
我在Log.cpp(而不是.h)中只定义了1个PANTHEIOS_FE_PROCESS_IDENTITY,如下所示,不仅适用于Log项目,而且适用于我的解决方案(VS2005)中需要访问记录器的其他项目:
PANTHEIOS_EXTERN_C const char PANTHEIOS_FE_PROCESS_IDENTITY[] = "l.SPP";
如果您使用PANTHEIOS_TRACE_NOTICE,您将从打印日志语句的位置获得文件名+行号-请参阅我上面发布的示例(粗体)。
我建议您确定是否真的需要为每个cpp文件或每个项目定义PANTHEIOS_FE_PROCESS_IDENTITY——我的经验表明后者就是答案。
这取决于PANTHEIOS_EXTERN_C
扩展到什么。如果它扩展到extern
——很可能——你会得到错误。
我要么完全删除它,要么取消定义。(我会选择第一个,不需要它是extern
。
注意在这种情况下,PANTHEIOS_FE_PROCESS_IDENTITY
不是全局的。如果您想使其全局化,您可以将其声明为extern,但只能在其中一个翻译单元中定义它。
因此:
如果PANTHEIOS_FE_PROCESS_IDENTITY
应该是全局的:
//log1.cpp
const PAN_CHAR_T PANTHEIOS_FE_PROCESS_IDENTITY[] = PSTR("fileX.cpp");
//definition here
//log2.cpp
PANTHEIOS_EXTERN_C const PAN_CHAR_T PANTHEIOS_FE_PROCESS_IDENTITY[];
//declared as extern here
如果不是,并且您希望这两个文件有所不同:
//log1.cpp
const PAN_CHAR_T PANTHEIOS_FE_PROCESS_IDENTITY[] = PSTR("fileX.cpp"); //not extern
//definition
//log2.cpp
const PAN_CHAR_T PANTHEIOS_FE_PROCESS_IDENTITY[] = PSTR("fileX.cpp"); //not extern
//definition
如果您想在一个文件file1.cpp中有一个const PANTHEIOS_FE_PROCESS_IDENTITY
,在另一个文件file 2.cpp中又有一个const PANTHEIOS_FE_PROCESS_IDENTITY
,则将其声明为static
,并且不会导出到文件之外。
PANTHEIOS_EXTERN_C static const PAN_CHAR_T PANTHEIOS_FE_PROCESS_IDENTITY[] = PSTR("fileX.cpp");
- 在提升multi_index容器中,是否定义了"default index"?
- #定义c-预处理器常量..我做错了什么
- 用C++中的一个变量定义一个常量
- 部分定义/别名模板模板参数
- C++映射:具有自定义类的运算符[]不起作用(总是返回0)
- #为""定义宏;静态";针对不同的上下文
- 如何确保C++函数在定义之前声明(如override关键字)
- 创建一个函数以在输入为负数或零时输出字符串.第一次执行用户定义的函数
- 当类在C++中定义时,有什么方法可以"register"类吗?
- 在命名空间中定义函数还是限定函数
- 此代码是否违反一个定义规则
- 编译C++时未定义的引用
- 不同翻译单元中不可重载的非内联函数定义
- 为什么在定义函数之前先声明它
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- 在类定义之后定义一个私有方法
- 使用用户定义函数的字符串反转
- 用户定义函数中的指针和输入
- vscode g++链路故障:体系结构x86_64的未定义符号
- 如何定义一个纯抽象基类