最近的一个程序中需要构建两个不同的类,他们继承与同一个父类,并且这两个子类有共同的"全局变量"变量,且这些"全局变量"只需要初始化一次。
因此就需要在父类中定义static ,当然大多数变量都是string bool等简单的变量。
class1.h
#ifndef _CLASS1_H__
#define _CLASS1_H__
#include <iostream>
using namespace std;
class class1{
public:
class1(int in);
~class1(){};
static int static_var;
static void initCfg();
int get_static_var();
};
#endif
class1.cpp
#include "class1.h"
class1::class1(int in)
{
static_var = in;
}
void class1::initCfg()
{
static_var = 0;
}
int class1::get_static_var()
{
return static_var;
}
class2.h
#ifndef _CLASS2_H__
#define _CLASS2_H__
#include <iostream>
#include "class1.h"
class class2 : public class1{
public:
class2(int in)
:class1(in)
{};
~class2(){};
change_static_var(int in);
private:
};
#endif
class2.cpp
#include "class2.h"
class2::change_static_var(int in)
{
static_var = in;
}
main.cpp
#include <iostream>
#include "class1.h"
#include "class2.h"
using namespace std;
int main()
{
class2 class2imple(2);
class2imple.change_static_var(56);
cout << class2imple.get_static_var() << endl;
return 0;
}
定义没有错,但是连接的时候出现这个问题。
class1.obj : error LNK2001: unresolved external symbol "public: static int class1::static_var" (?static_var@class1@@2HA)
class2.obj : error LNK2001: unresolved external symbol "public: static int class1::static_var" (?static_var@class1@@2HA)
错误描述的是puclic: static int class::static_var 是未决议的外部符号,思来想去不知道什么问题。但是作为静态成员变量需要在程序开始时分配内存空间是必要的。
一开始是我是这样改的:在父类中定义一个初始化静态成员变量的函数initCfg() 然后在主函数中这样调用。
#include <iostream>
#include "class1.h"
#include "class2.h"
using namespace std;
int main()
{
class1::initCfg();
class2 class2imple(2);
class2imple.change_static_var(56);
cout << class2imple.get_static_var() << endl;
return 0;
}
仍然是上述错误
第二次是直接在主函数之前初始化class1::static_var
#include <iostream>
#include "class1.h"
#include "class2.h"
using namespace std;
int class1::static_var;
int main()
{
class2 class2imple(2);
class2imple.change_static_var(56);
cout << class2imple.get_static_var() << endl;
return 0;
}
这样正确了,看来类中的静态变量和程序中的全局变量是等价的,只不过加入了类限制符号。
在程序使用静态变量之前必须初始化(并且声明所属类),否则程序出现未决外部符号?
这里的静态变量初始化比较奇怪,以前没用过这种方式初始化类静态成员变量,记录一下。