c++中静态成员变量为什么要在类外部再定义?
今天在编译tvision的Demo时遇到了很多链接错误,后来发现tvision的代码中很多类中声明的静态成员变量没有在类的实现文件中定义导致。
参考这里的讨论:
http://bbs.csdn.net/topics/360126427
问:
class testClass { public: static int m_i; }; int testClass::m_i; //类外部定义,若不写会产生error LNK2001: unresolved external symbol "public: static int testClass::m_i" (?m_i@testClass@@2HA) int main(int argc, char* argv[]) { printf("%d\n",testClass::m_i); printf("\n"); return 0; }
能否说说是什么原因?
答:
对于class的static data member,其实只是声明了一个scope(还记得class::static_data_member中的::么?),既然是声明而已,所以还需要一个定义,之所以需要在类的外面,因为本质来说它和global和static变量没什么区别,都是在数据段的,只是scope不一样,属于class而已。
这里反映出了C/C++里面一些稍微偏底层的复杂的细微的概念,比如scope,storage,life time。
::是指scope,是在class里面声明的,static指storage,是和global一样,在外面定义的。
更详细的原因请参考另一篇文章: