1

複数のファイルを含むプロジェクトに取り組んでおり、それぞれにログインする必要があります。

ファイルをコンパイルするには、次のものが必要です。

/* 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 にコンパイルされます。それはうまくいきます。

ここで、これら 2 つのファイルを 1 つの実行可能ファイルにリンクすると、次のエラーが発生します。

log2.o:(.rodata+0x11): multiple definition of `PANTHEIOS_FE_PROCESS_IDENTITY'
log1.o:(.rodata+0x45): first defined here

問題は、コンパイルするために PANTHEIOS_FE_PROCESS_IDENTITY を file1.cpp と file2.cpp の両方で定義する必要があることです。

コードを実行可能ファイルにリンクできるようにするには、コードをどのように変更する必要がありますか?

使用されるファイルは次のとおりです: 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-1.0.1-beta213/include/pantheios/frontends/stock.h:120 で 'PANTHEIOS_FE_PROCESS_IDENTITY' が extern として宣言されているため、静的として再定義できません。

4

3 に答える 3

2

私の質問/回答が奇妙に聞こえる場合は申し訳ありませんが、各 .cpp ファイルで PANTHEIOS_FE_PROCESS_IDENTITY を定義する必要があるのはなぜですか? PANTHEIOS_FE_PROCESS_IDENTITY は、ログ プロセスごとに 1 回だけ定義する必要があり、各行の先頭でログ ステートメントに出力されます。たとえば、私自身の pantheios ベースのロガー プロジェクトから:

[l.SPP.6408、2012 年 4 月 7 日 6:28:44.702 PM; Notice]: .\Log.cpp(168): CLogApp::InitInstance: ロギングを開始しています

PANTHEIOS_FE_PROCESS_IDENTITY が 1 つしか定義されていません - Log.cpp (.h ではありません)。次のように、LOG プロジェクトだけでなく、ロガーへのアクセスが必要な私のソリューション (VS2005) 内の他のプロジェクトにも適用できます。

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

PANTHEIOS_TRACE_NOTICE を使用すると、ログ ステートメントが出力されている場所からファイル名 + 行番号を取得できます。上記の例 (太字) を参照してください。

PANTHEIOS_FE_PROCESS_IDENTITY を本当に cpp ファイルごとまたはプロジェクトごとに定義する必要があるかどうかを判断することをお勧めします - 私の経験では、後者が答えであることが示されています。

于 2012-04-09T17:20:29.817 に答える
0

それは何にPANTHEIOS_EXTERN_C拡張するかに依存します。externそれが-おそらく-に拡大すると、エラーが発生します。

完全に削除するか、定義を解除します。(私は最初のものを使います、それがである必要はありませんextern

この場合、PANTHEIOS_FE_PROCESS_IDENTITYはグローバルではないことに注意してください。グローバルにしたい場合は、externとして宣言します、変換単位の1つでのみ定義します。

それで:

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

そうでない場合は、2つのファイルで異なるものにします。

//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
于 2012-04-03T14:30:39.793 に答える
0

const PANTHEIOS_FE_PROCESS_IDENTITYあるファイル file1.cpp と別のファイル file2.cpp にが必要な場合はconst PANTHEIOS_FE_PROCESS_IDENTITY、それを として宣言するとstatic、ファイルを超えてエクスポートされません。

PANTHEIOS_EXTERN_C static const PAN_CHAR_T PANTHEIOS_FE_PROCESS_IDENTITY[] = PSTR("fileX.cpp");
于 2012-04-03T15:05:24.700 に答える