1

次のファイルを取得します。

ああ

#ifndef A_H
#define A_H

char EL[] = "el";
#endif

a.cpp

#include "a.h"

bh

#ifndef B_H
#define B_H

#include "a.h"

#endif

b.cpp

#include "b.h"

main.cpp

#include "b.h"
#include "a.h"

int main() { }

これは単なる例ですが、私は本当にこの問題を抱えています:

g++ -c a.cpp
g++ -c b.cpp
g++ -c main.cpp
g++ -o main main.o a.o b.o


a.o:(.data+0x0): multiple definition of `EL'
main.o:(.data+0x0): first defined here
b.o:(.data+0x0): multiple definition of `EL'
main.o:(.data+0x0): first defined here
collect2: ld returned 1 exit status

なぜ、どのように解決するのですか?

4

1 に答える 1

8

複数の翻訳単位に定義を含める場合、インクルードガードはオブジェクトを複数回定義することから保護しません!

解決策として、ヘッダーで何かを定義するのではなく、宣言するだけです。

// header
extern char EL[2];

// TU
#include "header.h"
char EL[2] = "el";

// Other consumer
#include "header.h";
// can now use EL

(もちろん、例外もあります。たとえば、クラス定義は問題ありません (ただし、クラス メンバー関数の定義は問題ありません (ただし、インライン化されたものは問題あります)) -- 注意してください。)


static別の方法として、ヘッダー ファイルで次のように記述して、定義を各 TU に非公開にすることもできます。

// header
static char EL[] = "EL";  // every TU gets a copy

(ただし、C++0x では、静的リンケージのオブジェクトをテンプレート パラメーターとして使用することはできません。)

于 2011-07-23T23:26:49.000 に答える