我有多个类都是从基类派生的,现在某些派生类将不会根据平台进行编译。 我有一个允许我返回基类对象的类,但是现在派生类的所有名称都经过了硬编码。
有一种方法可以确定在运行时最好编译了哪些类,以便我可以删除链接并改为提供可动态加载的库。
我不知道您实际上要完成什么,但是您可以在每个派生类的实现文件中放置一个单例构造函数,该构造函数将名称添加到列表以及指向工厂的指针。 然后,列表始终是最新的,并且可以创建所有已编译的类。
通常,在C ++中依靠运行时类型信息是一个坏主意。 您所描述的似乎是工厂模式。 您可能要考虑为每个平台创建一个特殊的工厂子类,该子类仅知道该平台上存在的类。
有一些讨厌的,特定于编译器的技巧可以在运行时获取类信息。 相信我,您不想打开那种蠕虫。
在我看来,做到这一点的唯一严肃的方法是在每个派生类上使用条件编译。 在#ifdef块中,定义一个新常量,其中包含要编译的类名称。 然后,名称仍然是硬编码的,但都在中央位置。
派生类的名称必须使用C ++进行硬编码。 没有其他方法可以使用它们。 因此,不仅没有办法自动检测已经编译了哪些类,而且还没有办法使用该信息(如果存在)。
如果可以在运行时根据类的名称指定类,则类似于:
std :: string foo =“ Derived1”; Base * object = new“ foo”; //或您喜欢的任何符号-在C ++中不起作用
那么判断“ Derived1”是否已编译的功能将很有用。 由于您必须直接指定类,例如:
基础*对象=新的Derived1; //在C ++中有效
所有检查都在编译时完成。
如果每个类都有自己的动态库,只需检查该库是否存在。