关于类:C类的运行时知识

关于类:C类的运行时知识

C++ runtime knowledge of classes

我有多个类都是从基类派生的,现在某些派生类将不会根据平台进行编译。我有一个可以让我返回基类对象的类,但是现在派生类的所有名称都经过了硬编码。

是否有一种方法可以确定在运行时最好编译了哪些类,因此我可以删除链接并改为提供可动态加载的库。


您是否正在寻找C运行时类注册?我找到了此链接(备份)。

这可能会完成您想要的事情,我不确定动态加载的模块以及是否可以使用相同的方法注册它们。


我不知道您实际上要完成什么,但是您可以在每个派生类的实现文件中放置一个单例构造函数,该构造函数将名称添加到列表以及指向工厂的指针。然后,该列表始终是最新的,并且可以创建所有已编译的类。


通常,在C中依赖运行时类型信息是一个坏主意。您所描述的似乎是工厂模式。您可能要考虑为每个平台创建一个特殊的工厂子类,该子类仅知道该平台上存在的类。


派生类的名称必须用C进行硬编码。没有其他方法可以使用它们。因此,不仅没有办法自动检测已经编译了哪些类,而且还没有办法使用该信息(如果存在)。

如果可以在运行时根据类的名称指定类,例如:

std :: string foo = " Derived1 ";
Base * object = new " foo "; //或您喜欢的任何符号-在C

中不起作用

然后,判断" Derived1 "是否已编译的功能将很有用。由于您必须直接指定类,例如:

Base * object = new Derived1; //可以在C

中工作

所有检查均在编译时完成。


在运行时获取类信息时,有一些讨厌的,特定于编译器的技巧。相信我,您不想打开那种蠕虫。

在我看来,做到这一点的唯一严肃方法是在每个派生类上使用条件编译。在#ifdef块中,定义一个新常量,其中包含要编译的类名称。然后,名称仍然是硬编码的,但都在中央位置。


这听起来像是使用"编译时多态"或模板策略参数的地方。

请参阅Andrei Alexandrescu撰写的Modern C Design及其基于本书的Loki实现。另请参阅Wikipedia上的Loki页面。


如果每个类都有自己的动态库,只需检查该库是否存在。


推荐阅读