首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何避免PANTHEIOS_FE_PROCESS_IDENTITY的多个定义?

如何避免PANTHEIOS_FE_PROCESS_IDENTITY的多个定义?
EN

Stack Overflow用户
提问于 2012-04-03 22:26:27
回答 3查看 1.3K关注 0票数 1

我正在处理一个有多个文件的项目,我需要记录每个文件。

为了编译一个文件,我需要以下内容:

代码语言:javascript
复制
/* 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。这很好用。

现在,当我将这两个文件链接到一个可执行文件中时,我得到以下错误:

代码语言:javascript
复制
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:

代码语言:javascript
复制
#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:

代码语言:javascript
复制
#include "log.h"
const PAN_CHAR_T PANTHEIOS_FE_PROCESS_IDENTITY[] = PSTR("log1.cpp");

log.h:

代码语言:javascript
复制
#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的输出:

代码语言:javascript
复制
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-1.0.1-beta213/include/pantheios/frontends/stock.h:120中‘PANTHEIOS_FE_PROCESS_IDENTITY’被声明为外部,所以我不能将其重新定义为静态。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-04-10 01:20:30

如果我的问题/答案听起来很奇怪,我真的很抱歉:但是为什么要在每个.cpp文件中定义PANTHEIOS_FE_PROCESS_IDENTITY?对于每个日志记录过程,只需定义一次PANTHEIOS_FE_PROCESS_IDENTITY,并在每行开头将其打印到日志语句中。例如,来自我自己的基于pantheios的记录器项目:

l.SPP.6408,4/7/2012 6:28:44.702 PM;注意:.\Log.cpp(168):CLogApp::InitInstance:启动日志

我只有一个定义在Log.cpp中的PANTHEIOS_FE_PROCESS_IDENTITY (不是.h)。如下所示,不仅适用于日志项目,还适用于我的解决方案(VS2005)中需要访问记录器的其他项目:

PANTHEIOS_EXTERN_C const char PANTHEIOS_FE_PROCESS_IDENTITY[] = "l.SPP";

如果您使用PANTHEIOS_TRACE_NOTICE,您将从输出日志语句的位置获得文件名+行号-参见我在上面发布的示例(粗体)。

我建议您确定是否真的需要为每个cpp文件或每个项目定义PANTHEIOS_FE_PROCESS_IDENTITY --我的经验表明,后者才是答案。

票数 2
EN

Stack Overflow用户

发布于 2012-04-03 22:30:40

这取决于PANTHEIOS_EXTERN_C扩展到什么。如果它扩展到extern -很有可能-你会得到错误。

我要么完全删除它,要么取消它的定义。(我会选择第一个,不需要它是extern

注意,在这种情况下,PANTHEIOS_FE_PROCESS_IDENTITY不是全局的。如果您想使其成为全局的,您可以将其声明为外部,但仅在其中一个转换单元中定义它。

所以:

如果PANTHEIOS_FE_PROCESS_IDENTITY应该是全局的:

代码语言:javascript
复制
//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

如果不是,并且您希望这两个文件的情况有所不同:

代码语言:javascript
复制
//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
票数 0
EN

Stack Overflow用户

发布于 2012-04-03 23:05:25

如果您想在一个文件file1.cpp中创建一个const PANTHEIOS_FE_PROCESS_IDENTITY,在另一个文件file2.cpp中创建另一个const PANTHEIOS_FE_PROCESS_IDENTITY,那么将其声明为static,它将不会被导出到该文件之外。

代码语言:javascript
复制
PANTHEIOS_EXTERN_C static const PAN_CHAR_T PANTHEIOS_FE_PROCESS_IDENTITY[] = PSTR("fileX.cpp");
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9995320

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档