使用以下代码时,我对链接器错误感到困惑:
// 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)。
我的代码可能有什么问题?
答案 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;
};