5

我有一个导出 C++ 类的 MFC 扩展 DLL,我需要修改类方法的行为。这些更改不会影响类方法的签名。

我不想重新编译使用该库先前发布版本的“lib”文件的模块。

如果更改修改了函数的入口点地址会发生什么?

比如构造函数的地址发生了变化:

Export   Ordinal      Function    Hint                      Entry Point
[+  ]    3 (0x0003)   2 (0x0002)  ??0CLangManager@@QAE@XZ   0x00009CB0    (OLD DLL)
[+  ]    3 (0x0003)   2 (0x0002)  ??0CLangManager@@QAE@XZ   0x00009760    (NEW DLL)

我是否应该重新编译使用该库的模块?

我使用发布的可执行文件测试了重新编译的库 - 使用新的入口点,一切正常。我不确定这种情况是否隐藏了一些副作用。

什么时候需要重新编译链接到 DLL 的可执行文件?

二进制兼容性何时被破坏?

4

1 回答 1

2

这是使用 DLL 的好处之一——您可以更改它,只要您继续保持相同的函数签名,一切都会正常工作。加载程序时会发生链接,因此地址的更改不会产生任何影响。

您将绝对肯定 DLL 中定义的任何类都没有任何内联方法,因为这些方法可能不适用于对象的任何内部更改。

当函数签名更改或公共成员变量更改对象内的位置时,二进制兼容性会被破坏。我会完全避免 DLL 中的公共成员变量。

编辑:如评论中所述,如果将变量添加到类中或从类中删除,更改其大小,您也可能会遇到麻烦。如果对象是在 DLL 之外创建的,无论是作为局部变量还是通过new. 您可以通过从 DLL 内部创建所有对象实例并将指针传递给调用者来避免这种情况。您还可以通过在您的课程中使用PIMPL 习语来避免问题。

于 2013-02-22T17:04:00.257 回答