c++ - tlb 文件是否具有关联架构?

标签 c++ windows com 32bit-64bit

我有一个 32 位 DLL,旨在通过 com 模型和关联的 tlb 文件进行访问。

DLL 似乎是 x86。

有什么方法可以从 x64 程序访问这种 DLL 吗? tlb 文件是否与 x86/x64 无关?

我问是因为某些功能似乎有效,有些功能崩溃了,并且o̶t̶h̶e̶a̶a̶m̶e̶m̶i̶s̶s̶s̶s̶i̶n̶g̶c̶o̶c̶o̶m̶m̶p̶a̶e̶e̶e̶e̶e̶e̶t̶e̶t̶o̶t̶o̶t̶o̶

--编辑--

由于 OEM 方面的错误,出现缺少的程序集。

最佳答案

在大多数情况下,类型库当然旨在与平台无关。您在 Microsoft 提供的 Windows 编程中遇到的大多数都是。在 .NET 中最为明显,这使得编写可在 32 位或 64 位模式下运行的代码变得非常简单,由 AnyCPU 平台目标公开。使用 Microsoft.Office.Interop 中的互操作类或编写在 Office 程序中运行的扩展都不需要什么特别的,您使用完全相同的类型库。

但是当您使用由从未考虑过它在 64 位代码上工作的程序员创建的类型库时,这并不总是那么有效。最典型的问题是由方法参数引起的,这些方法参数实际上是引擎盖下的指针,但被扁平化为整数类型,long 是典型的选择。这些指针值在 64 位模式下为 64 位宽,当您尝试将它们填充为 32 位整数时会出现错误。 HANDLE 值就是一个很好的例子。

到目前为止,最臭名昭著的 oops 是 Microsoft 的。 ADO 的类型库已损坏,这是一个广泛用于与数据库引擎对话的数据库提供程序库。他们在 Windows 7 SP1 中进行了重大更改,当程序员在该操作系统中构建程序并发现它不再适用于旧版本的 Windows 时,这一更改导致了广泛的痛苦。糟糕的是,这种类型在 64 位操作系统上应该是 32 位的,但在 64 位操作系统上却被声明为 64 位。当您拥有 Windows SDK 版本 8、adoint_Backcompat.h 头文件、ADO_LONGPTR 类型时,您会看到此错误。在 adoint.h 中被 long 替换。

最好与原始程序员一起解决这个问题。或者,为了利用 COM 代理,它们可以在从 64 位进程调用时在进程外运行 32 位代码。

关于c++ - tlb 文件是否具有关联架构?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16661056/

相关文章:

c++ - 我如何与 C++ 中的其他应用程序交互?

c++ - SignedXML 类等于 Visual C++?

c++ - 创建随机数量的对象

c++ - COM MFC 应用程序不显示窗口

.Net 替换 VBScript (interop.msscriptcontrol.dll) DLL

c++ - 支持 VS 中的 C++ 重构(自动更新引用和 header /cpp)

php - Apache 2.2.14 + php_apc.dll 崩溃

c# - 有没有办法判断映射的驱动器是用 C# 映射为管理员还是标准用户?

windows - 设置 Jenkins 时权限被拒绝(公钥)

c# - 我怎么能够创建接口(interface) Microsoft.Office.Interop.Word.Application 的新实例