【发布时间】:2010-10-29 00:40:59
【问题描述】:
我有一个 .NET dll,它有一些暴露给 com 的接口\类。在构建过程中会生成一个 .tlb 文件,并且该 tlb 被一些 c++ 代码引用。因此,编译器会为 tlb 生成一个 .tlh 文件。
当我在本地运行构建时,其中一个接口中的属性之一最终会在 tlh 中具有不同名称的相应方法。 .net 代码中的属性称为 PropertyA,最终称为 get_propertyA,而 PropertyB 最终称为 get_PropertyB。发生这种情况时,我没有眨眼,只是使用了 tlh 中定义的方法并假设一切都是 hunky dory,但是当我提交这些更改时,构建对其他人不起作用,因为编译器生成了名为 get_PropertyA 的属性和get_PropertyB(注意 propertyA 中的大小写不匹配)。
在两台机器上生成的 tlb 文件是相同的(根据十六进制比较器),并且 tlh 文件都是由相同的编译器版本生成的。
构建过程通过执行以下操作创建 tlb:regasm path\to\dll\Mydll.dll -tlb:path\to\output\mydll.tlb
任何想法为什么我的本地版本最终会出现名称不正确的属性?或者我能做些什么来解决它?
更新:我读到 tlbexp 将使用它找到的字符串的第一个版本,并且可以通过重新编译来改变。虽然我没有使用 tlbexp,但我想知道这是否是问题所在。我找到了与我的方法(在其他方法中)同名的参数,但开头有一个小写字母。所以我把这些都换了。重建,没有变化。所以我然后重命名了我的 COM 方法。重新构建并得到预期的缺失方法错误。将该方法重命名为原始名称,嘿,它似乎已修复。由于它现在似乎可以工作并且我不能让它再次失败,所以我无法尝试建议的解决方案,但我喜欢重命名的想法,以防将来发生这种情况。
【问题讨论】:
-
使用“重命名”解决方法时要小心 - 它的工作方式类似于简单的文本替换,有时会导致奇怪的结果。我已经更新了答案以概述这一点。
-
感谢您的提醒。如果出现问题,我会记住这一点。
标签: .net compiler-construction com interop typelib