反射在.net证明了它的灵活性,它使得一个类可以动态地实例化。
如 IFruit fruit = (IFruit)Assembly.Load("反射程序集").CreateInstance("命名空间.Apple");
这样就实例出一个Apple的实例出来。
下面使用C++来模拟这种方式。
1.利用模板
模板的功能十分的强大,这个在STL和boost已经充分的体现出来。
#include<iostream>
#include<memory>
Using namespace std;
class fruit{
public:
virtual void said() = 0;
};
class apple :public fruit{
public:
void said(){
cout<<"apple"<<endl;
}
};
class banana :public fruit{
public:
void said(){
cout<<"banana"<<endl;
}
};
class pear :public fruit{
public:
void said(){
cout<<"pear"<<endl;
}
};
class fruit_factory{
public:
template<class T>
static auto_ptr<T> create_fruit(){
return auto_ptr<T>(new T());
}
};
int main(void)
{
auto_ptr<fruit> a = new auto_ptr<apple>(new apple);
a->said();
auto_ptr<fruit> f = fruit_factory::create_fruit<pear>();
f->said();
auto_ptr<fruit> b = fruit_factory::create_fruit<banana>();
b->said();
return 0;
}
第二种方式:利用宏来定义水果工厂
#define CREATE_FRUIT(fruit_name) /
new fruit_name();
int main(void)
{
fruit *a = CREATE_FRUIT(apple);
a->said();
fruit *b = CREATE_FRUIT(banana);
b->said();
fruit *p = CREATE_FRUIT(pear);
p->said();
return 0;
}
可惜还不知如何像.net那样真正地进行反射,如将要实例化的对象置于配置文件,配置后重新启动即改变程序的行为。