C++虽无原生反射,但可通过工厂模式+注册机制实现:1. 用std::map映射类名与创建函数;2. 提供registerClass和create方法实现动态创建;3. 利用静态Registrar在全局构造时自动注册;4. 扩展ClassInfo管理属性方法信息,结合宏简化注册,适用于序列化等场景。

在C++中,语言本身不支持像Java或C#那样的原生反射机制,但可以通过一些技巧实现一个简单的反射系统。核心思路是通过手动注册类与创建函数的映射关系,结合工厂模式和类型信息管理,实现根据字符串动态创建对象的能力。
1. 使用类名映射创建函数
最基础的反射功能是根据类名字符串创建对应类型的对象。这可以通过一个全局的映射表(如std::map<:string std::function>)来实现,将类名与对应的构造函数绑定。
示例思路:
- 定义一个基类(通常带虚析构函数),作为所有可反射类的公共接口。
- 每个派生类提供一个静态创建函数,返回该类的新实例。
- 在程序启动时,将类名与创建函数注册到工厂中。
- 通过类名查找并调用对应函数,完成对象创建。
2. 实现一个简单反射工厂
定义一个模板化工厂类,管理类名到构造函数的映射:
立即学习“C++免费学习笔记(深入)”;
class ObjectFactory {
public:
template
void registerClass(const std::string& name) {
creators[name] = []() -> T* { return new T(); };
}
Base* create(const std::string& name) {
if (creators.find(name) != creators.end()) {
return creators[name]();
}
return nullptr;
}private:
std::map<:string std::function>> creators;
};
使用方式:先注册类,再通过名字创建:
ObjectFactory factory; factory.registerClass("DerivedA"); factory.registerClass ("DerivedB"); Base* obj = factory.create("DerivedA"); // 返回 DerivedA 实例
3. 自动注册机制(避免手动调用register)
可以通过全局变量的构造函数,在程序启动时自动完成注册,减少使用负担。
实现方法:
- 定义一个注册器类,其构造函数将类的创建函数插入工厂。
- 在每个派生类的实现文件中定义一个静态注册器变量。
- 利用全局变量初始化时机,自动完成注册。
例如:
templateclass Registrar { public: Registrar(const std::string& name) { ObjectFactory::instance().registerClass (name); } }; // 在 .cpp 文件中 static Registrar
regA("DerivedA");
4. 扩展功能:属性与方法反射
如果需要访问字段或调用方法,可以进一步设计属性描述结构体,包含名称、类型、偏移量或访问器函数,并将其注册到类描述器中。
常见做法:
- 为每个类维护一个ClassInfo对象,包含类名、父类、属性列表等。
- 属性使用void*指针加类型标签或访问器函数(getter/setter)表示。
- 通过宏简化注册代码,如REGISTER_PROPERTY(className, fieldName)。
基本上就这些。虽然C++没有内置反射,但通过工厂+注册+宏的组合,可以实现一个轻量级、实用的反射系统,适用于序列化、编辑器、插件系统等场景。关键是设计清晰的接口和自动化的注册流程,减少重复代码。











