6

我的游戏库由一系列模块组成,按类组织,在需要时创建、更新和交互。

一些示例可能是:CWindowManagerCGraphicsManagerCPhysicsManager等。

我很惭愧不得不说我目前对它们使用全局指针(extern CWindowManager* g_WindowManager;),而且我知道这可能是一件坏事。

无论如何,问题是这些模块需要动态地创建和删除,当然是按照正确的顺序。还有一个问题是,像这样CPhysicsManager的模块依赖于场景,因此在切换场景时它们会被删除,然后重新创建。

现在,我想放弃使用全局变量来处理我的游戏中的模块。

我不害怕重构,但我真的想不出什么是全局变量的最佳替代方案。

我考虑过创建一个 CModuleManager 类并将模块的实例存储在其中作为成员,然后从 CModule 基类派生。虽然我无法真正想到这将如何详细工作。

这似乎是软件开发,尤其是游戏开发中的一个常见问题,所以:

- 与简单地使用全局指针相比,管理模块的最佳选择是什么?

4

1 回答 1

1

使用全局数据时需要考虑的一些事项:

  • 多线程。如果不同线程可以同时访问全局数据,则需要小心。
  • 可测试性。如果您正在编写单元测试,则需要在任何代码访问全局数据之前初始化全局数据。

使用全局数据的替代方法是将每个类/方法所需的对象实例作为参数传递。这样做的好处是类的所有依赖项都可以从 API 中看到。它还使编写单元测试变得更加容易。缺点是如果您在各处传递对象,代码可能会变得混乱。

您拥有 ModuleManager 的想法听起来像 Service Locator 模式——我认为这是一个可行的解决方案。此链接可能会有所帮助: http: //gameprogrammingpatterns.com/service-locator.html

如果选择继续使用全局指针,则可以在 C++ 中使用智能指针 (auto_ptr) 实现动态删除全局数据。

于 2011-08-22T13:57:31.943 回答