Windows 软件设计:如何获取DLL版本号

Windows 软件设计:如何获取DLL版本号,windows,Windows,我在法规遵从性场景中使用了一个DLL(其细节与此无关)。重要的一点是,主可执行文件必须显示DLL版本号。我的解决方案是,DLL有一个函数来返回它自己的版本——即从它自己的版本资源中获取它并将其作为字符串返回 我的审阅者说主程序应该计算出DLL版本号。他甚至给了我一些代码来获取DLL模块句柄并使用它提取版本 我的问题是,哪种设计更好,为什么?我的感觉是,使用OO原则,我应该询问DLL的版本号。以另一种方式执行意味着主程序需要知道版本信息是如何存储的,因此与实现的耦合更紧密 请注意,我确切地知道如何

我在法规遵从性场景中使用了一个DLL(其细节与此无关)。重要的一点是,主可执行文件必须显示DLL版本号。我的解决方案是,DLL有一个函数来返回它自己的版本——即从它自己的版本资源中获取它并将其作为字符串返回

我的审阅者说主程序应该计算出DLL版本号。他甚至给了我一些代码来获取DLL模块句柄并使用它提取版本

我的问题是,哪种设计更好,为什么?我的感觉是,使用OO原则,我应该询问DLL的版本号。以另一种方式执行意味着主程序需要知道版本信息是如何存储的,因此与实现的耦合更紧密


请注意,我确切地知道如何从DLL中提取版本信息。我的问题是关于执行此操作的代码的最佳位置。

您能否澄清您所处的环境?现在,既然你已经提到了获得模块句柄,我假设你使用C++,调用一个Win32函数(GoMe调器句柄,LoadLibrary等)。 首先,我要小心在过于广泛的环境中应用OO原则。面向对象范例可以帮助您以更易于维护和理解的方式构建软件,您描述的问题听起来可能超出了应用程序的边界。如果您想获取关于一个单独的资源(例如DLL)的信息,您应该考虑使用一种标准方法来实现这一点,以确保代码与需要检查的项目脱钩。 如果在DLL中引入函数以将版本号返回到主应用程序,则在主应用程序和任何需要提供其版本信息的DLL之间创建了紧密耦合(通过为此定义定制API或接口)

您应该考虑使用标准的、跨平台的功能来检索信息,而这将允许您的应用程序为其获得句柄的任何DLL版本。

假设您有一个用于dll的HMODULE(并且您正在使用C++),请调用以下函数以获取版本

GetModuleFileNameEx(如果您还不知道,请获取DLL的完整路径和文件名)

使用此文件名,调用

GetFileVersionInfo大小(在MSDN上查找)

这将告诉您有关文件版本元数据的一些重要信息(文件有多少信息,如果有的话)。假设此函数成功,则调用

GetFileVersionInfo

这将把所有文件信息元数据加载到缓冲区中,然后调用

VerQueryValue

提供“\”作为lpSubBlock参数以获取标准文件信息元数据(包括版本号)

上述函数将允许您编写代码,以获取代码可以获得句柄的任何模块的版本号


当然,如果您使用C#,解决方案要简单得多。希望这有帮助……

答案取决于细节(因此它们是相关的)。根据这里提供的信息,我可以凭良心为这两种情况辩护。(我还怀疑没有明确的答案,这只是一个设计决策问题。)我认为这两种方法都可以,尽管GetFileVersionInfo()是通用的,可以与任何DLL一起使用。唯一需要注意的是,您需要确保版本信息是准确的;理想情况下,这应该由构建系统自动完成。让每个DLL负责报告自己的版本意味着在每个DLL中重复相同的代码,这违反了DRY。由于版本戳记是标准化的,在这里封装并没有真正的好处,除非您打算在将来更改为非标准版本戳记方案。天哪!真正的雷蒙德陈在评论!