gpt4 book ai didi

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

转载 作者:可可西里 更新时间:2023-11-01 13:29:17 25 4
gpt4 key购买 nike

我有一个 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com