“static const int”导致链接错误(未定义引用)

时间:2011-04-01 01:03:41

标签: c++ gcc static const stdvector

使用以下代码时,我对链接器错误感到困惑:

// static_const.cpp -- complete code
#include <vector>

struct Elem {
    static const int value = 0;
};

int main(int argc, char *argv[]) {
    std::vector<Elem> v(1);
    std::vector<Elem>::iterator it;

    it = v.begin();
    return it->value;
}

然而,这在链接时失败 - 不知何故它需要有一个静态const“值的符号。”

$ g++ static_const.cpp 
/tmp/ccZTyfe7.o: In function `main':
static_const.cpp:(.text+0x8e): undefined reference to `Elem::value'
collect2: ld returned 1 exit status
顺便说一句,这可以用-O1或更好的编译好;但对于更复杂的情况,它仍然失败。我使用的是gcc版本4.4.4 20100726(Red Hat 4.4.4-13)。

我的代码可能有什么问题?

6 个答案:

答案 0 :(得分:8)

如果你想在 struct 中初始化它,你也可以这样做:

struct Elem {
    static const int value = 0;
};

const int Elem::value;

答案 1 :(得分:5)

尝试将其写为

struct Elem {
    static const int value;
};

const int Elem::value = 0;

etc

答案 2 :(得分:2)

static类成员通常应该在一个编译单元中定义在类外部(在内部声明,在外部定义)。

我不记得它是如何与const静态积分成员的内联初始化交互的。

答案 3 :(得分:2)

另见this post:基本上,问题是编译器最终会将代码扩展为使用Elem :: value的地址。

答案 4 :(得分:1)

为什么不这样做?

return Elem::value;

但答案是你在声明中指定了一个值。这应该适用于int这样的基本类型,并且只对复杂类型(即类,如果你有一个字符串而不是int)需要。我在实践中发现的是,这取决于您使用的编译器的版本。并且,正如您所发现的那样,哪个优化级别。

答案 5 :(得分:1)

在大多数定义类static const <integral type>的编译器中,都可以正常工作。但是某些编译器(例如Android NDK)之类的定义会导致链接器错误。在这种情况下,我们可以使用键入的enum

struct X
{
  enum : int64_t { VALUE = 100; }; // == static const int64_t VALUE = 100;
};