1

有人可以建议吗?

如果const在 C++ 中默认为内部链接,为什么在下面的代码中会出现多个定义错误?

首先,文件dem.h

#ifndef _DEM_H_
    #define _DEM_H_
    class Dem {
        public:
            static const int i;
    };

    const int Dem::i = 10;
#endif

他们imp1.cpp

#include "dem.h"
#include <iostream>

using namespace std;
extern int foo();

int main() {
        cout << foo() << endl;
}

imp2.cpp

#include "dem.h"

int foo() {
    return Dem::i ;
}

我使用以下命令和结果进行编译:

$ g++ imp1.cpp imp2.cpp
/tmp/ccmGt0OY.o:imp2.cpp:(.rdata+0x0): multiple definition of `Dem::i'
/tmp/cc5sN7dz.o:imp1.cpp:(.rdata+0x0): first defined here
collect2: ld returned 1 exit status
4

2 回答 2

3

从 C++11 [basic.link],第 5 段:

此外,成员函数、静态数据成员、类范围的命名类或枚举,或在类范围 typedef 声明中定义的未命名类或枚举,使得类或枚举具有用于链接目的的 typedef 名称 (7.1. 3),如果类名有外部链接,则有外部链接。

因为你的类有外部链接,所以你的静态数据成员也有。

于 2012-04-05T03:45:36.463 回答
0

它对编译单元是静态的。您分两步进行编译——首先是 impl1.cpp,然后是 impl2.cpp——并且在每个单元中,编译器都会实例化静态数据成员。当链接器尝试将两个关联的目标文件链接在一起时,它会看到同一个符号的两个不同定义,因此您会收到多重定义错误。

于 2012-04-05T03:49:56.337 回答